Nsphinx.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]hPortuguese (Brazilian)}hhsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget-/translations/pt_BR/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 }(hj hhhNhNubhstrong)}(h**ieee80211_ptr**h]h ieee80211_ptr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh pointer to a }(hj hhhNhNubh)}(h,:c:type:`struct wireless_dev `h]hliteral)}(hj)h]hstruct wireless_dev}(hj-hhhNhNubah}(h]h ](xrefcc-typeeh"]h$]h&]uh1j+hj'ubah}(h]h ]h"]h$]h&]refdocdriver-api/80211/cfg80211 refdomainj8reftypetype refexplicitrefwarn reftarget wireless_devuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:11: ./include/net/cfg80211.hhK0hj ubhX; 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.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjLhK0hhhhubh)}(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.}(hjWhhhNhNubah}(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_flagshNtauh1jfhhhhhNhNubhdesc)}(hhh](hdesc_signature)}(hieee80211_channel_flagsh]hdesc_signature_line)}(henum ieee80211_channel_flagsh](hdesc_sig_keyword)}(henumh]henum}(hjhhhNhNubah}(h]h ]kah"]h$]h&]uh1jhjhhh`/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&]uh1jhjhhhjhKubh desc_name)}(hieee80211_channel_flagsh]h desc_sig_name)}(hjh]hieee80211_channel_flags}(hjhhhNhNubah}(h]h ]nah"]h$]h&]uh1jhjubah}(h]h ](sig-namedescnameeh"]h$]h&] xml:spacepreserveuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jj add_permalinkuh1jsphinx_line_type declaratorhj~hhhjhKubah}(h]juah ](sig sig-objecteh"]h$]h&] is_multiline _toc_parts) _toc_namehuh1j|hjhKhjyhhubh 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&]uh1jhjyhhhjhKubeh}(h]h ](j8enumeh"]h$]h&]domainj8objtypejdesctypejnoindex noindexentrynocontentsentryuh1jwhhhhhNhNubh container)}(hX{ **Constants** ``IEEE80211_CHAN_DISABLED`` This channel is disabled. ``IEEE80211_CHAN_NO_IR`` do not initiate radiation, this includes sending probe requests or beaconing. ``IEEE80211_CHAN_PSD`` Power spectral density (in dBm) is set for this channel. ``IEEE80211_CHAN_RADAR`` Radar detection is required on this channel. ``IEEE80211_CHAN_NO_HT40PLUS`` extension channel above this channel is not permitted. ``IEEE80211_CHAN_NO_HT40MINUS`` extension channel below this channel is not permitted. ``IEEE80211_CHAN_NO_OFDM`` OFDM is not allowed on this channel. ``IEEE80211_CHAN_NO_80MHZ`` If the driver supports 80 MHz on the band, this flag indicates that an 80 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. ``IEEE80211_CHAN_NO_160MHZ`` If the driver supports 160 MHz on the band, this flag indicates that an 160 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. ``IEEE80211_CHAN_INDOOR_ONLY`` see ``NL80211_FREQUENCY_ATTR_INDOOR_ONLY`` ``IEEE80211_CHAN_IR_CONCURRENT`` see ``NL80211_FREQUENCY_ATTR_IR_CONCURRENT`` ``IEEE80211_CHAN_NO_20MHZ`` 20 MHz bandwidth is not permitted on this channel. ``IEEE80211_CHAN_NO_10MHZ`` 10 MHz bandwidth is not permitted on this channel. ``IEEE80211_CHAN_NO_HE`` HE operation is not permitted on this channel. ``IEEE80211_CHAN_NO_UHR`` UHR operation is not permitted on this channel. ``IEEE80211_CHAN_NO_320MHZ`` If the driver supports 320 MHz on the band, this flag indicates that a 320 MHz channel cannot use this channel as the control or any of the secondary channels. This may be due to the driver or due to regulatory bandwidth restrictions. ``IEEE80211_CHAN_NO_EHT`` EHT operation is not permitted on this channel. ``IEEE80211_CHAN_DFS_CONCURRENT`` See ``NL80211_RRF_DFS_CONCURRENT`` ``IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT`` Client connection with VLP AP not permitted using this channel ``IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT`` Client connection with AFC AP not permitted using this channel ``IEEE80211_CHAN_CAN_MONITOR`` This channel can be used for monitor mode even in the presence of other (regulatory) restrictions, even if it is otherwise disabled. ``IEEE80211_CHAN_ALLOW_6GHZ_VLP_AP`` Allow using this channel for AP operation with very low power (VLP), even if otherwise set to NO_IR. ``IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY`` Allow activity on a 20 MHz channel, even if otherwise set to NO_IR. ``IEEE80211_CHAN_S1G_NO_PRIMARY`` Prevents the channel for use as an S1G primary channel. Does not prevent the wider operating channel described by the chandef from being used. In order for a 2MHz primary to be used, both 1MHz subchannels shall not contain this flag. ``IEEE80211_CHAN_NO_4MHZ`` 4 MHz bandwidth is not permitted on this channel. ``IEEE80211_CHAN_NO_8MHZ`` 8 MHz bandwidth is not permitted on this channel. ``IEEE80211_CHAN_NO_16MHZ`` 16 MHz bandwidth is not permitted on this channel.h](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(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,)}(hj3h]hIEEE80211_CHAN_DISABLED}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj1ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKOhj+ubh definition)}(hhh]h)}(hThis channel is disabled.h]hThis channel is disabled.}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHhKOhjKubah}(h]h ]h"]h$]h&]uh1jIhj+ubeh}(h]h ]h"]h$]h&]uh1j)hjHhKOhj&ubj*)}(hg``IEEE80211_CHAN_NO_IR`` do not initiate radiation, this includes sending probe requests or beaconing. h](j0)}(h``IEEE80211_CHAN_NO_IR``h]j,)}(hjnh]hIEEE80211_CHAN_NO_IR}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjlubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKShjhubjJ)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKRhjubah}(h]h ]h"]h$]h&]uh1jIhjhubeh}(h]h ]h"]h$]h&]uh1j)hjhKShj&ubj*)}(hP``IEEE80211_CHAN_PSD`` Power spectral density (in dBm) is set for this channel. h](j0)}(h``IEEE80211_CHAN_PSD``h]j,)}(hjh]hIEEE80211_CHAN_PSD}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKWhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKWhj&ubj*)}(hF``IEEE80211_CHAN_RADAR`` Radar detection is required on this channel. h](j0)}(h``IEEE80211_CHAN_RADAR``h]j,)}(hjh]hIEEE80211_CHAN_RADAR}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKZhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKZhj&ubj*)}(hV``IEEE80211_CHAN_NO_HT40PLUS`` extension channel above this channel is not permitted. h](j0)}(h``IEEE80211_CHAN_NO_HT40PLUS``h]j,)}(hjh]hIEEE80211_CHAN_NO_HT40PLUS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhK^hjubjJ)}(hhh]h)}(h6extension channel above this channel is not permitted.h]h6extension channel above this channel is not permitted.}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhK]hj1ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj0hK^hj&ubj*)}(hW``IEEE80211_CHAN_NO_HT40MINUS`` extension channel below this channel is not permitted. h](j0)}(h``IEEE80211_CHAN_NO_HT40MINUS``h]j,)}(hjUh]hIEEE80211_CHAN_NO_HT40MINUS}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjSubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKbhjOubjJ)}(hhh]h)}(h6extension channel below this channel is not permitted.h]h6extension channel below this channel is not permitted.}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKahjkubah}(h]h ]h"]h$]h&]uh1jIhjOubeh}(h]h ]h"]h$]h&]uh1j)hjjhKbhj&ubj*)}(h@``IEEE80211_CHAN_NO_OFDM`` OFDM is not allowed on this channel. h](j0)}(h``IEEE80211_CHAN_NO_OFDM``h]j,)}(hjh]hIEEE80211_CHAN_NO_OFDM}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKehjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKehj&ubj*)}(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](j0)}(h``IEEE80211_CHAN_NO_80MHZ``h]j,)}(hjh]hIEEE80211_CHAN_NO_80MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKlhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKlhj&ubj*)}(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](j0)}(h``IEEE80211_CHAN_NO_160MHZ``h]j,)}(hjh]hIEEE80211_CHAN_NO_160MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKshjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKshj&ubj*)}(hJ``IEEE80211_CHAN_INDOOR_ONLY`` see ``NL80211_FREQUENCY_ATTR_INDOOR_ONLY`` h](j0)}(h``IEEE80211_CHAN_INDOOR_ONLY``h]j,)}(hj<h]hIEEE80211_CHAN_INDOOR_ONLY}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj:ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKvhj6ubjJ)}(hhh]h)}(h*see ``NL80211_FREQUENCY_ATTR_INDOOR_ONLY``h](hsee }(hjUhhhNhNubj,)}(h&``NL80211_FREQUENCY_ATTR_INDOOR_ONLY``h]h"NL80211_FREQUENCY_ATTR_INDOOR_ONLY}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjUubeh}(h]h ]h"]h$]h&]uh1hhjQhKvhjRubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j)hjQhKvhj&ubj*)}(hN``IEEE80211_CHAN_IR_CONCURRENT`` see ``NL80211_FREQUENCY_ATTR_IR_CONCURRENT`` h](j0)}(h ``IEEE80211_CHAN_IR_CONCURRENT``h]j,)}(hjh]hIEEE80211_CHAN_IR_CONCURRENT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKyhj}ubjJ)}(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&]uh1j+hjubeh}(h]h ]h"]h$]h&]uh1hhjhKyhjubah}(h]h ]h"]h$]h&]uh1jIhj}ubeh}(h]h ]h"]h$]h&]uh1j)hjhKyhj&ubj*)}(hO``IEEE80211_CHAN_NO_20MHZ`` 20 MHz bandwidth is not permitted on this channel. h](j0)}(h``IEEE80211_CHAN_NO_20MHZ``h]j,)}(hjh]hIEEE80211_CHAN_NO_20MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhK}hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhK}hj&ubj*)}(hO``IEEE80211_CHAN_NO_10MHZ`` 10 MHz bandwidth is not permitted on this channel. h](j0)}(h``IEEE80211_CHAN_NO_10MHZ``h]j,)}(hjh]hIEEE80211_CHAN_NO_10MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(hhh]h)}(h210 MHz bandwidth is not permitted on this channel.h]h210 MHz bandwidth is not permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj&ubj*)}(hH``IEEE80211_CHAN_NO_HE`` HE operation is not permitted on this channel. h](j0)}(h``IEEE80211_CHAN_NO_HE``h]j,)}(hj>h]hIEEE80211_CHAN_NO_HE}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj<ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj8ubjJ)}(hhh]h)}(h.HE operation is not permitted on this channel.h]h.HE operation is not permitted on this channel.}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShKhjTubah}(h]h ]h"]h$]h&]uh1jIhj8ubeh}(h]h ]h"]h$]h&]uh1j)hjShKhj&ubj*)}(hJ``IEEE80211_CHAN_NO_UHR`` UHR operation is not permitted on this channel. h](j0)}(h``IEEE80211_CHAN_NO_UHR``h]j,)}(hjwh]hIEEE80211_CHAN_NO_UHR}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjuubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjqubjJ)}(hhh]h)}(h/UHR operation is not permitted on this channel.h]h/UHR operation is not permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jIhjqubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj&ubj*)}(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](j0)}(h``IEEE80211_CHAN_NO_320MHZ``h]j,)}(hjh]hIEEE80211_CHAN_NO_320MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj&ubj*)}(hJ``IEEE80211_CHAN_NO_EHT`` EHT operation is not permitted on this channel. h](j0)}(h``IEEE80211_CHAN_NO_EHT``h]j,)}(hjh]hIEEE80211_CHAN_NO_EHT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj&ubj*)}(hE``IEEE80211_CHAN_DFS_CONCURRENT`` See ``NL80211_RRF_DFS_CONCURRENT`` h](j0)}(h!``IEEE80211_CHAN_DFS_CONCURRENT``h]j,)}(hj#h]hIEEE80211_CHAN_DFS_CONCURRENT}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj!ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(hhh]h)}(h"See ``NL80211_RRF_DFS_CONCURRENT``h](hSee }(hj<hhhNhNubj,)}(h``NL80211_RRF_DFS_CONCURRENT``h]hNL80211_RRF_DFS_CONCURRENT}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj<ubeh}(h]h ]h"]h$]h&]uh1hhj8hKhj9ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj8hKhj&ubj*)}(he``IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT`` Client connection with VLP AP not permitted using this channel h](j0)}(h%``IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT``h]j,)}(hjjh]h!IEEE80211_CHAN_NO_6GHZ_VLP_CLIENT}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjhubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjdubjJ)}(hhh]h)}(h>Client connection with VLP AP not permitted using this channelh]h>Client connection with VLP 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&]uh1jIhjdubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj&ubj*)}(he``IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT`` Client connection with AFC AP not permitted using this channel h](j0)}(h%``IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT``h]j,)}(hjh]h!IEEE80211_CHAN_NO_6GHZ_AFC_CLIENT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj&ubj*)}(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](j0)}(h``IEEE80211_CHAN_CAN_MONITOR``h]j,)}(hjh]hIEEE80211_CHAN_CAN_MONITOR}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj&ubj*)}(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](j0)}(h$``IEEE80211_CHAN_ALLOW_6GHZ_VLP_AP``h]j,)}(hjh]h IEEE80211_CHAN_ALLOW_6GHZ_VLP_AP}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(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.}(hj1hhhNhNubah}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj-hKhj&ubj*)}(hl``IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY`` Allow activity on a 20 MHz channel, even if otherwise set to NO_IR. h](j0)}(h'``IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY``h]j,)}(hjRh]h#IEEE80211_CHAN_ALLOW_20MHZ_ACTIVITY}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjPubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjLubjJ)}(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.}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjhubah}(h]h ]h"]h$]h&]uh1jIhjLubeh}(h]h ]h"]h$]h&]uh1j)hjghKhj&ubj*)}(hX ``IEEE80211_CHAN_S1G_NO_PRIMARY`` Prevents the channel for use as an S1G primary channel. Does not prevent the wider operating channel described by the chandef from being used. In order for a 2MHz primary to be used, both 1MHz subchannels shall not contain this flag. h](j0)}(h!``IEEE80211_CHAN_S1G_NO_PRIMARY``h]j,)}(hjh]hIEEE80211_CHAN_S1G_NO_PRIMARY}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(hhh]h)}(hPrevents the channel for use as an S1G primary channel. Does not prevent the wider operating channel described by the chandef from being used. In order for a 2MHz primary to be used, both 1MHz subchannels shall not contain this flag.h]hPrevents the channel for use as an S1G primary channel. Does not prevent the wider operating channel described by the chandef from being used. In order for a 2MHz primary to be used, both 1MHz subchannels shall not contain this flag.}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj&ubj*)}(hM``IEEE80211_CHAN_NO_4MHZ`` 4 MHz bandwidth is not permitted on this channel. h](j0)}(h``IEEE80211_CHAN_NO_4MHZ``h]j,)}(hjh]hIEEE80211_CHAN_NO_4MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(hhh]h)}(h14 MHz bandwidth is not permitted on this channel.h]h14 MHz bandwidth is not permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj&ubj*)}(hM``IEEE80211_CHAN_NO_8MHZ`` 8 MHz bandwidth is not permitted on this channel. h](j0)}(h``IEEE80211_CHAN_NO_8MHZ``h]j,)}(hjh]hIEEE80211_CHAN_NO_8MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(hhh]h)}(h18 MHz bandwidth is not permitted on this channel.h]h18 MHz bandwidth is not permitted on this channel.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj&ubj*)}(hN``IEEE80211_CHAN_NO_16MHZ`` 16 MHz bandwidth is not permitted on this channel.h](j0)}(h``IEEE80211_CHAN_NO_16MHZ``h]j,)}(hj8h]hIEEE80211_CHAN_NO_16MHZ}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj2ubjJ)}(hhh]h)}(h216 MHz bandwidth is not permitted on this channel.h]h216 MHz bandwidth is not permitted on this channel.}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjNubah}(h]h ]h"]h$]h&]uh1jIhj2ubeh}(h]h ]h"]h$]h&]uh1j)hjMhKhj&ubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hj{h]h Description}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(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.hhKIhhhhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsieee80211_channel (C struct)c.ieee80211_channelhNtauh1jfhhhhhNhNubjx)}(hhh](j})}(hieee80211_channelh]j)}(hstruct ieee80211_channelh](j)}(hstructh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/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&]jjjuh1jjjhjhhhjhKNubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhKNhjhhubj)}(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 ](j8structeh"]h$]h&]jj8jj jj jjjuh1jwhhhhhNhNubj)}(hX**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; u64 cac_start_time; 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. ``cac_start_time`` timestamp (CLOCK_BOOTTIME, nanoseconds) when CAC was started on this channel. Zero when CAC is not in progress. ``psd`` power spectral density (in dBm)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(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: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; u64 cac_start_time; 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; u64 cac_start_time; s8 psd; };}hj; sbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubh)}(h **Members**h]j)}(hjL h]hMembers}(hjN hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJ 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](j0)}(h``band``h]j,)}(hjk h]hband}(hjm hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hji ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhje ubjJ)}(hhh]h)}(hband this channel belongs to.h]hband this channel belongs to.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1jIhje ubeh}(h]h ]h"]h$]h&]uh1j)hj hKhjb ubj*)}(h(``center_freq`` center frequency in MHz h](j0)}(h``center_freq``h]j,)}(hj h]h center_freq}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubjJ)}(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&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj hKhjb ubj*)}(h4``freq_offset`` offset from **center_freq**, in KHz h](j0)}(h``freq_offset``h]j,)}(hj h]h freq_offset}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubjJ)}(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&]uh1jhj ubh, in KHz}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj hKhjb ubj*)}(h5``hw_value`` hardware-specific value for the channel h](j0)}(h ``hw_value``h]j,)}(hj( h]hhw_value}(hj* hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj& ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj" ubjJ)}(hhh]h)}(h'hardware-specific value for the channelh]h'hardware-specific value for the channel}(hjA hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj= hKhj> ubah}(h]h ]h"]h$]h&]uh1jIhj" ubeh}(h]h ]h"]h$]h&]uh1j)hj= hKhjb ubj*)}(h_``flags`` channel flags from :c:type:`enum ieee80211_channel_flags `. h](j0)}(h ``flags``h]j,)}(hja h]hflags}(hjc hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj_ ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj[ ubjJ)}(hhh]h)}(hTchannel flags from :c:type:`enum ieee80211_channel_flags `.h](hchannel flags from }(hjz hhhNhNubh)}(h@:c:type:`enum ieee80211_channel_flags `h]j,)}(hj h]henum ieee80211_channel_flags}(hj hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarn c:parent_keysphinx.domains.c LookupKey)}data]sbjJieee80211_channel_flagsuh1hhjv hKhjz ubh.}(hjz hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjv hKhjw ubah}(h]h ]h"]h$]h&]uh1jIhj[ ubeh}(h]h ]h"]h$]h&]uh1j)hjv hKhjb ubj*)}(h1``max_antenna_gain`` maximum antenna gain in dBi h](j0)}(h``max_antenna_gain``h]j,)}(hj h]hmax_antenna_gain}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubjJ)}(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&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj hKhjb ubj*)}(h2``max_power`` maximum transmission power (in dBm) h](j0)}(h ``max_power``h]j,)}(hj h]h max_power}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubjJ)}(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&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj hKhjb ubj*)}(hA``max_reg_power`` maximum regulatory transmission power (in dBm) h](j0)}(h``max_reg_power``h]j,)}(hj7 h]h max_reg_power}(hj9 hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj5 ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj1 ubjJ)}(hhh]h)}(h.maximum regulatory transmission power (in dBm)h]h.maximum regulatory transmission power (in dBm)}(hjP hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjL hKhjM ubah}(h]h ]h"]h$]h&]uh1jIhj1 ubeh}(h]h ]h"]h$]h&]uh1j)hjL hKhjb 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](j0)}(h``beacon_found``h]j,)}(hjp h]h beacon_found}(hjr hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjn ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjj ubjJ)}(hhh]h)}(hhelper to regulatory code to indicate when a beacon has been found on this channel. Use regulatory_hint_found_beacon() to enable this, this is useful only on 5 GHz band.h]hhelper to regulatory code to indicate when a beacon has been found on this channel. Use regulatory_hint_found_beacon() to enable this, this is useful only on 5 GHz band.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubah}(h]h ]h"]h$]h&]uh1jIhjj ubeh}(h]h ]h"]h$]h&]uh1j)hj hKhjb ubj*)}(h{``orig_flags`` channel flags at registration time, used by regulatory code to support devices with additional restrictions h](j0)}(h``orig_flags``h]j,)}(hj h]h orig_flags}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubjJ)}(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&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj hKhjb ubj*)}(h``orig_mag`` internal use h](j0)}(h ``orig_mag``h]j,)}(hj h]horig_mag}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubjJ)}(hhh]h)}(h internal useh]h internal use}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj hKhjb ubj*)}(h``orig_mpwr`` internal use h](j0)}(h ``orig_mpwr``h]j,)}(hj h]h orig_mpwr}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubjJ)}(hhh]h)}(h internal useh]h internal use}(hj6 hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2 hKhj3 ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj2 hKhjb ubj*)}(ha``dfs_state`` current state of this channel. Only relevant if radar is required on this channel. h](j0)}(h ``dfs_state``h]j,)}(hjV h]h dfs_state}(hjX hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjT ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjP ubjJ)}(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.}(hjo hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjl ubah}(h]h ]h"]h$]h&]uh1jIhjP ubeh}(h]h ]h"]h$]h&]uh1j)hjk hKhjb ubj*)}(hJ``dfs_state_entered`` timestamp (jiffies) when the dfs state was entered. h](j0)}(h``dfs_state_entered``h]j,)}(hj h]hdfs_state_entered}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubjJ)}(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&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj hKhjb ubj*)}(hM``dfs_cac_ms`` DFS CAC time in milliseconds, this is valid for DFS channels. h](j0)}(h``dfs_cac_ms``h]j,)}(hj h]h dfs_cac_ms}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubjJ)}(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&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj hKhjb ubj*)}(h``cac_start_time`` timestamp (CLOCK_BOOTTIME, nanoseconds) when CAC was started on this channel. Zero when CAC is not in progress. h](j0)}(h``cac_start_time``h]j,)}(hj h]hcac_start_time}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj ubjJ)}(hhh]h)}(hotimestamp (CLOCK_BOOTTIME, nanoseconds) when CAC was started on this channel. Zero when CAC is not in progress.h]hotimestamp (CLOCK_BOOTTIME, nanoseconds) when CAC was started on this channel. Zero when CAC is not in progress.}(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&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj hKhjb ubj*)}(h'``psd`` power spectral density (in dBm)h](j0)}(h``psd``h]j,)}(hj< h]hpsd}(hj> hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj: ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj6 ubjJ)}(hhh]h)}(hpower spectral density (in dBm)h]hpower spectral density (in dBm)}(hjU hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjR ubah}(h]h ]h"]h$]h&]uh1jIhj6 ubeh}(h]h ]h"]h$]h&]uh1j)hjQ hKhjb ubeh}(h]h ]h"]h$]h&]uh1j$hj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj} ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhhhubh)}(h@This structure describes a single channel for use with cfg80211.h]h@This structure describes a single channel for use with cfg80211.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhhhhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsieee80211_rate_flags (C enum)c.ieee80211_rate_flagshNtauh1jfhhhhhNhNubjx)}(hhh](j})}(hieee80211_rate_flagsh]j)}(henum ieee80211_rate_flagsh](j)}(hjh]henum}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj 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&]uh1jhj hhhj hKubj)}(hieee80211_rate_flagsh]j)}(hj h]hieee80211_rate_flags}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj hhhj hKubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj hhhj hKubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1j|hj hKhj 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&]uh1jhj hhhj hKubeh}(h]h ](j8enumeh"]h$]h&]jj8jjjjjjjuh1jwhhhhhNhNubj)}(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&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubj%)}(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](j0)}(h!``IEEE80211_RATE_SHORT_PREAMBLE``h]j,)}(hj@h]hIEEE80211_RATE_SHORT_PREAMBLE}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj>ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj:ubjJ)}(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.}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjVubah}(h]h ]h"]h$]h&]uh1jIhj:ubeh}(h]h ]h"]h$]h&]uh1j)hjUhKhj7ubj*)}(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](j0)}(h``IEEE80211_RATE_MANDATORY_A``h]j,)}(hjzh]hIEEE80211_RATE_MANDATORY_A}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjxubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjtubjJ)}(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.}(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&]uh1jIhjtubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj7ubj*)}(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](j0)}(h``IEEE80211_RATE_MANDATORY_B``h]j,)}(hjh]hIEEE80211_RATE_MANDATORY_B}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(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.hhKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj7ubj*)}(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](j0)}(h``IEEE80211_RATE_MANDATORY_G``h]j,)}(hjh]hIEEE80211_RATE_MANDATORY_G}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj7ubj*)}(h>``IEEE80211_RATE_ERP_G`` This is an ERP rate in 802.11g mode. h](j0)}(h``IEEE80211_RATE_ERP_G``h]j,)}(hj(h]hIEEE80211_RATE_ERP_G}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj&ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj"ubjJ)}(hhh]h)}(h$This is an ERP rate in 802.11g mode.h]h$This is an ERP rate in 802.11g mode.}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=hKhj>ubah}(h]h ]h"]h$]h&]uh1jIhj"ubeh}(h]h ]h"]h$]h&]uh1j)hj=hKhj7ubj*)}(h@``IEEE80211_RATE_SUPPORTS_5MHZ`` Rate can be used in 5 MHz mode h](j0)}(h ``IEEE80211_RATE_SUPPORTS_5MHZ``h]j,)}(hjah]hIEEE80211_RATE_SUPPORTS_5MHZ}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj_ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj[ubjJ)}(hhh]h)}(hRate can be used in 5 MHz modeh]hRate can be used in 5 MHz mode}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhKhjwubah}(h]h ]h"]h$]h&]uh1jIhj[ubeh}(h]h ]h"]h$]h&]uh1j)hjvhKhj7ubj*)}(hA``IEEE80211_RATE_SUPPORTS_10MHZ`` Rate can be used in 10 MHz modeh](j0)}(h!``IEEE80211_RATE_SUPPORTS_10MHZ``h]j,)}(hjh]hIEEE80211_RATE_SUPPORTS_10MHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhjubjJ)}(hhh]h)}(hRate can be used in 10 MHz modeh]hRate can be used in 10 MHz mode}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhKhj7ubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(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.hhKhhhhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsieee80211_rate (C struct)c.ieee80211_ratehNtauh1jfhhhhhNhNubjx)}(hhh](j})}(hieee80211_rateh]j)}(hstruct ieee80211_rateh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/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&]uh1jhjhhhj(hKubj)}(hieee80211_rateh]j)}(hjh]hieee80211_rate}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj(hKubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhj(hKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hj(hKhjhhubj)}(hhh]h)}(hbitrate definitionh]hbitrate definition}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjZhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj(hKubeh}(h]h ](j8structeh"]h$]h&]jj8jjujjujjjuh1jwhhhhhNhNubj)}(hX**Definition**:: struct ieee80211_rate { u32 flags; u16 bitrate; u16 hw_value, hw_value_short; }; **Members** ``flags`` rate-specific flags from :c:type:`enum ieee80211_rate_flags ` ``bitrate`` bitrate in units of 100 Kbps ``hw_value`` driver/hardware value for this rate ``hw_value_short`` driver/hardware value for this rate when short preamble is usedh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubh:}(hj}hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjyubj: )}(h\struct ieee80211_rate { u32 flags; u16 bitrate; u16 hw_value, hw_value_short; };h]h\struct ieee80211_rate { u32 flags; u16 bitrate; u16 hw_value, hw_value_short; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM!hjyubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM'hjyubj%)}(hhh](j*)}(h^``flags`` rate-specific flags from :c:type:`enum ieee80211_rate_flags ` h](j0)}(h ``flags``h]j,)}(hjh]hflags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM#hjubjJ)}(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 ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJieee80211_rate_flagsuh1hhjhM#hjubeh}(h]h ]h"]h$]h&]uh1hhjhM#hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM#hjubj*)}(h)``bitrate`` bitrate in units of 100 Kbps h](j0)}(h ``bitrate``h]j,)}(hj"h]hbitrate}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$hjubjJ)}(hhh]h)}(hbitrate in units of 100 Kbpsh]hbitrate in units of 100 Kbps}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hM$hj8ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj7hM$hjubj*)}(h1``hw_value`` driver/hardware value for this rate h](j0)}(h ``hw_value``h]j,)}(hj[h]hhw_value}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjYubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM%hjUubjJ)}(hhh]h)}(h#driver/hardware value for this rateh]h#driver/hardware value for this rate}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhjphM%hjqubah}(h]h ]h"]h$]h&]uh1jIhjUubeh}(h]h ]h"]h$]h&]uh1j)hjphM%hjubj*)}(hR``hw_value_short`` driver/hardware value for this rate when short preamble is usedh](j0)}(h``hw_value_short``h]j,)}(hjh]hhw_value_short}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hjubjJ)}(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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM&hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM&hjubeh}(h]h ]h"]h$]h&]uh1j$hjyubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(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&]uh1jhjubh and }(hjhhhNhNubj)}(h**hw_value_short**h]hhw_value_short}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhK 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.hhMhhhhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsieee80211_sta_ht_cap (C struct)c.ieee80211_sta_ht_caphNtauh1jfhhhhhNhNubjx)}(hhh](j})}(hieee80211_sta_ht_caph]j)}(hstruct ieee80211_sta_ht_caph](j)}(hjh]hstruct}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$ubj)}(h h]h }(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4hhhjEhM$ubj)}(hieee80211_sta_ht_caph]j)}(hj2h]hieee80211_sta_ht_cap}(hjXhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjTubah}(h]h ](jjeh"]h$]h&]jjuh1jhj4hhhjEhM$ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj0hhhjEhM$ubah}(h]j+ah ](jjeh"]h$]h&]jj)jhuh1j|hjEhM$hj-hhubj)}(hhh]h)}(hSTA's HT capabilitiesh]hSTA’s HT capabilities}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMShjwhhubah}(h]h ]h"]h$]h&]uh1jhj-hhhjEhM$ubeh}(h]h ](j8structeh"]h$]h&]jj8jjjjjjjuh1jwhhhhhNhNubj)}(hX**Definition**:: struct ieee80211_sta_ht_cap { u16 cap; bool ht_supported; u8 ampdu_factor; u8 ampdu_density; struct ieee80211_mcs_info mcs; }; **Members** ``cap`` HT capabilities map as described in 802.11n spec ``ht_supported`` is HT supported by the STA ``ampdu_factor`` Maximum A-MPDU length factor ``ampdu_density`` Minimum A-MPDU spacing ``mcs`` Supported MCS ratesh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMWhjubj: )}(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; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMYhjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMahjubj%)}(hhh](j*)}(h9``cap`` HT capabilities map as described in 802.11n spec h](j0)}(h``cap``h]j,)}(hjh]hcap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMZhjubjJ)}(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&]uh1hhjhMZhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMZhjubj*)}(h,``ht_supported`` is HT supported by the STA h](j0)}(h``ht_supported``h]j,)}(hj h]h ht_supported}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMYhjubjJ)}(hhh]h)}(his HT supported by the STAh]his HT supported by the STA}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hMYhj6ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj5hMYhjubj*)}(h.``ampdu_factor`` Maximum A-MPDU length factor h](j0)}(h``ampdu_factor``h]j,)}(hjYh]h ampdu_factor}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjWubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM[hjSubjJ)}(hhh]h)}(hMaximum A-MPDU length factorh]hMaximum A-MPDU length factor}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhM[hjoubah}(h]h ]h"]h$]h&]uh1jIhjSubeh}(h]h ]h"]h$]h&]uh1j)hjnhM[hjubj*)}(h)``ampdu_density`` Minimum A-MPDU spacing h](j0)}(h``ampdu_density``h]j,)}(hjh]h ampdu_density}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM\hjubjJ)}(hhh]h)}(hMinimum A-MPDU spacingh]hMinimum A-MPDU spacing}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM\hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM\hjubj*)}(h``mcs`` Supported MCS ratesh](j0)}(h``mcs``h]j,)}(hjh]hmcs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM\hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM\hjubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(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.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMThhhhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js#ieee80211_supported_band (C struct)c.ieee80211_supported_bandhNtauh1jfhhhhhNhNubjx)}(hhh](j})}(hieee80211_supported_bandh]j)}(hstruct ieee80211_supported_bandh](j)}(hjh]hstruct}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMZubj)}(h h]h }(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHhhhjYhMZubj)}(hieee80211_supported_bandh]j)}(hjFh]hieee80211_supported_band}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubah}(h]h ](jjeh"]h$]h&]jjuh1jhjHhhhjYhMZubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjDhhhjYhMZubah}(h]j?ah ](jjeh"]h$]h&]jj)jhuh1j|hjYhMZhjAhhubj)}(hhh]h)}(hfrequency band definitionh]hfrequency band definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM2hjhhubah}(h]h ]h"]h$]h&]uh1jhjAhhhjYhMZubeh}(h]h ](j8structeh"]h$]h&]jj8jjjjjjjuh1jwhhhhhNhNubj)}(hXS**Definition**:: struct ieee80211_supported_band { struct ieee80211_channel *channels; struct ieee80211_rate *bitrates; enum nl80211_band band; int n_channels; int n_bitrates; struct ieee80211_sta_ht_cap ht_cap; struct ieee80211_sta_vht_cap vht_cap; struct ieee80211_sta_s1g_cap s1g_cap; struct ieee80211_edmg edmg_cap; u16 n_iftype_data; const struct ieee80211_sband_iftype_data __iftd *iftype_data; }; **Members** ``channels`` Array of channels the hardware can operate with in this band. ``bitrates`` Array of bitrates the hardware can operate with in this band. Must be sorted to give a valid "supported rates" IE, i.e. CCK rates first, then OFDM. ``band`` the band this structure represents ``n_channels`` Number of channels in **channels** ``n_bitrates`` Number of bitrates in **bitrates** ``ht_cap`` HT capabilities in this band ``vht_cap`` VHT capabilities in this band ``s1g_cap`` S1G capabilities in this band (S1G band only, of course) ``edmg_cap`` EDMG capabilities in this band ``n_iftype_data`` number of iftype data entries ``iftype_data`` interface type data entries. Note that the bits in **types_mask** inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_data).h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hjubj: )}(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&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM8hjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMFhjubj%)}(hhh](j*)}(hK``channels`` Array of channels the hardware can operate with in this band. h](j0)}(h ``channels``h]j,)}(hjh]hchannels}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM9hjubjJ)}(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.hhM8hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM9hjubj*)}(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](j0)}(h ``bitrates``h]j,)}(hj5h]hbitrates}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj3ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM>hj/ubjJ)}(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.}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM<hjKubah}(h]h ]h"]h$]h&]uh1jIhj/ubeh}(h]h ]h"]h$]h&]uh1j)hjJhM>hjubj*)}(h,``band`` the band this structure represents h](j0)}(h``band``h]j,)}(hjoh]hband}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjmubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM:hjiubjJ)}(hhh]h)}(h"the band this structure representsh]h"the band this structure represents}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM:hjubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j)hjhM:hjubj*)}(h2``n_channels`` Number of channels in **channels** h](j0)}(h``n_channels``h]j,)}(hjh]h n_channels}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM;hjubjJ)}(hhh]h)}(h"Number of channels in **channels**h](hNumber of channels in }(hjhhhNhNubj)}(h **channels**h]hchannels}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhM;hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM;hjubj*)}(h2``n_bitrates`` Number of bitrates in **bitrates** h](j0)}(h``n_bitrates``h]j,)}(hjh]h n_bitrates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM?hjubjJ)}(hhh]h)}(h"Number of bitrates in **bitrates**h](hNumber of bitrates in }(hjhhhNhNubj)}(h **bitrates**h]hbitrates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhM?hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM?hjubj*)}(h(``ht_cap`` HT capabilities in this band h](j0)}(h ``ht_cap``h]j,)}(hj6h]hht_cap}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj4ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM@hj0ubjJ)}(hhh]h)}(hHT capabilities in this bandh]hHT capabilities in this band}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhM@hjLubah}(h]h ]h"]h$]h&]uh1jIhj0ubeh}(h]h ]h"]h$]h&]uh1j)hjKhM@hjubj*)}(h*``vht_cap`` VHT capabilities in this band h](j0)}(h ``vht_cap``h]j,)}(hjoh]hvht_cap}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjmubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMAhjiubjJ)}(hhh]h)}(hVHT capabilities in this bandh]hVHT capabilities in this band}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMAhjubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j)hjhMAhjubj*)}(hE``s1g_cap`` S1G capabilities in this band (S1G band only, of course) h](j0)}(h ``s1g_cap``h]j,)}(hjh]hs1g_cap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMDhjubjJ)}(hhh]h)}(h8S1G capabilities in this band (S1G band only, of course)h]h8S1G capabilities in this band (S1G band only, of course)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMDhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMDhjubj*)}(h,``edmg_cap`` EDMG capabilities in this band h](j0)}(h ``edmg_cap``h]j,)}(hjh]hedmg_cap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMChjubjJ)}(hhh]h)}(hEDMG capabilities in this bandh]hEDMG capabilities in this band}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMChjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMChjubj*)}(h0``n_iftype_data`` number of iftype data entries h](j0)}(h``n_iftype_data``h]j,)}(hjh]h n_iftype_data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMEhjubjJ)}(hhh]h)}(hnumber of iftype data entriesh]hnumber of iftype data entries}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hMEhj0ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj/hMEhjubj*)}(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](j0)}(h``iftype_data``h]j,)}(hjSh]h iftype_data}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjQubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMHhjMubjJ)}(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 }(hjlhhhNhNubj)}(h**types_mask**h]h types_mask}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubh} inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_data).}(hjlhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMFhjiubah}(h]h ]h"]h$]h&]uh1jIhjMubeh}(h]h ]h"]h$]h&]uh1j)hjhhMHhjubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMLhhhhubh)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM3hhhhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js&wiphy_read_of_freq_limits (C function)c.wiphy_read_of_freq_limitshNtauh1jfhhhhhNhNubjx)}(hhh](j})}(h4void wiphy_read_of_freq_limits (struct wiphy *wiphy)h]j)}(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}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubhdesc_parameterlist)}(h(struct wiphy *wiphy)h]hdesc_parameter)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubj)}(h h]h }(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubh)}(hhh]j)}(hwiphyh]hwiphy}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&] refdomainj8reftype identifier reftargetjJmodnameN classnameNj j )}j ]j ASTIdentifier)}j^j sbc.wiphy_read_of_freq_limitsasbuh1hhj&ubj)}(h h]h }(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubhdesc_sig_punctuation)}(h*h]h*}(hj{hhhNhNubah}(h]h ]pah"]h$]h&]uh1jyhj&ubj)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhMhjhhubj)}(hhh]h)}(h&read frequency limits from device treeh]h&read frequency limits from device tree}(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&]uh1jhjhhhjhMubeh}(h]h ](j8functioneh"]h$]h&]jj8jjjjjjjuh1jwhhhhhNhNubj)}(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&]uh1jhjubah}(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](j0)}(h``struct wiphy *wiphy``h]j,)}(hjh]hstruct wiphy *wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hMhjubah}(h]h ]h"]h$]h&]uh1j$hjubh)}(h**Description**h]j)}(hj0h]h Description}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(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).}(hjFhhhNhNubah}(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 }(hjUhhhNhNubhemphasis)}(h*modify*h]hmodify}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1j]hjUubh7 channels (disable unavailable ones). It’s usually a }(hjUhhhNhNubj^)}(h*bad*h]hbad}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j]hjUubh 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.}(hjUhhhNhNubeh}(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().}(hjhhhNhNubah}(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&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jscfg80211_signal_type (C enum)c.cfg80211_signal_typehNtauh1jfhhhhhNhNubjx)}(hhh](j})}(hcfg80211_signal_typeh]j)}(henum cfg80211_signal_typeh](j)}(hjh]henum}(hjhhhNhNubah}(h]h ]jah"]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)}(hcfg80211_signal_typeh]j)}(hjh]hcfg80211_signal_type}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhMhjhhubj)}(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&]uh1jhjhhhjhMubeh}(h]h ](j8enumeh"]h$]h&]jj8jjjjjjjuh1jwhhhhhNhNubj)}(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&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubj%)}(hhh](j*)}(hG``CFG80211_SIGNAL_TYPE_NONE`` no signal strength information available h](j0)}(h``CFG80211_SIGNAL_TYPE_NONE``h]j,)}(hj<h]hCFG80211_SIGNAL_TYPE_NONE}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj:ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj6ubjJ)}(hhh]h)}(h(no signal strength information availableh]h(no signal strength information available}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQhM hjRubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j)hjQhM hj3ubj*)}(h>``CFG80211_SIGNAL_TYPE_MBM`` signal strength in mBm (100*dBm) h](j0)}(h``CFG80211_SIGNAL_TYPE_MBM``h]j,)}(hjuh]hCFG80211_SIGNAL_TYPE_MBM}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjsubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjoubjJ)}(hhh]h)}(h signal strength in mBm (100*dBm)h]h signal strength in mBm (100*dBm)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjoubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj3ubj*)}(hN``CFG80211_SIGNAL_TYPE_UNSPEC`` signal strength, increasing from 0 through 100h](j0)}(h``CFG80211_SIGNAL_TYPE_UNSPEC``h]j,)}(hjh]hCFG80211_SIGNAL_TYPE_UNSPEC}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h.signal strength, increasing from 0 through 100h]h.signal strength, increasing from 0 through 100}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj3ubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jswiphy_params_flags (C enum)c.wiphy_params_flagshNtauh1jfhhhhhNhNubjx)}(hhh](j})}(hwiphy_params_flagsh]j)}(henum wiphy_params_flagsh](j)}(hjh]henum}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/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}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhM hjhhubj)}(hhh]h)}(h set_wiphy_params bitfield valuesh]h set_wiphy_params bitfield values}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM5hjGhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j8enumeh"]h$]h&]jj8jjbjjbjjjuh1jwhhhhhNhNubj)}(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)}(hjlh]h Constants}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM9hjfubj%)}(hhh](j*)}(h;``WIPHY_PARAM_RETRY_SHORT`` wiphy->retry_short has changed h](j0)}(h``WIPHY_PARAM_RETRY_SHORT``h]j,)}(hjh]hWIPHY_PARAM_RETRY_SHORT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM<hjubjJ)}(hhh]h)}(hwiphy->retry_short has changedh]hwiphy->retry_short has changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM<hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM<hjubj*)}(h9``WIPHY_PARAM_RETRY_LONG`` wiphy->retry_long has changed h](j0)}(h``WIPHY_PARAM_RETRY_LONG``h]j,)}(hjh]hWIPHY_PARAM_RETRY_LONG}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM?hjubjJ)}(hhh]h)}(hwiphy->retry_long has changedh]hwiphy->retry_long has changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM?hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM?hjubj*)}(hA``WIPHY_PARAM_FRAG_THRESHOLD`` wiphy->frag_threshold has changed h](j0)}(h``WIPHY_PARAM_FRAG_THRESHOLD``h]j,)}(hjh]hWIPHY_PARAM_FRAG_THRESHOLD}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMBhjubjJ)}(hhh]h)}(h!wiphy->frag_threshold has changedh]h!wiphy->frag_threshold has changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMBhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMBhjubj*)}(h?``WIPHY_PARAM_RTS_THRESHOLD`` wiphy->rts_threshold has changed h](j0)}(h``WIPHY_PARAM_RTS_THRESHOLD``h]j,)}(hj6h]hWIPHY_PARAM_RTS_THRESHOLD}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj4ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMEhj0ubjJ)}(hhh]h)}(h wiphy->rts_threshold has changedh]h wiphy->rts_threshold has changed}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhMEhjLubah}(h]h ]h"]h$]h&]uh1jIhj0ubeh}(h]h ]h"]h$]h&]uh1j)hjKhMEhjubj*)}(h6``WIPHY_PARAM_COVERAGE_CLASS`` coverage class changed h](j0)}(h``WIPHY_PARAM_COVERAGE_CLASS``h]j,)}(hjoh]hWIPHY_PARAM_COVERAGE_CLASS}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjmubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMHhjiubjJ)}(hhh]h)}(hcoverage class changedh]hcoverage class changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMHhjubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j)hjhMHhjubj*)}(h0``WIPHY_PARAM_DYN_ACK`` dynack has been enabled h](j0)}(h``WIPHY_PARAM_DYN_ACK``h]j,)}(hjh]hWIPHY_PARAM_DYN_ACK}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMKhjubjJ)}(hhh]h)}(hdynack has been enabledh]hdynack has been enabled}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMKhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMKhjubj*)}(h<``WIPHY_PARAM_TXQ_LIMIT`` TXQ packet limit has been changed h](j0)}(h``WIPHY_PARAM_TXQ_LIMIT``h]j,)}(hjh]hWIPHY_PARAM_TXQ_LIMIT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMNhjubjJ)}(hhh]h)}(h!TXQ packet limit has been changedh]h!TXQ packet limit has been changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMNhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMNhjubj*)}(hC``WIPHY_PARAM_TXQ_MEMORY_LIMIT`` TXQ memory limit has been changed h](j0)}(h ``WIPHY_PARAM_TXQ_MEMORY_LIMIT``h]j,)}(hjh]hWIPHY_PARAM_TXQ_MEMORY_LIMIT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMQhjubjJ)}(hhh]h)}(h!TXQ memory limit has been changedh]h!TXQ memory limit has been changed}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hMQhj0ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj/hMQhjubj*)}(h1``WIPHY_PARAM_TXQ_QUANTUM`` TXQ scheduler quantumh](j0)}(h``WIPHY_PARAM_TXQ_QUANTUM``h]j,)}(hjSh]hWIPHY_PARAM_TXQ_QUANTUM}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjQubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMShjMubjJ)}(hhh]h)}(hTXQ scheduler quantumh]hTXQ scheduler quantum}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMThjiubah}(h]h ]h"]h$]h&]uh1jIhjMubeh}(h]h ]h"]h$]h&]uh1j)hjhhMShjubeh}(h]h ]h"]h$]h&]uh1j$hjfubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jswiphy_flags (C enum) c.wiphy_flagshNtauh1jfhhhhhNhNubjx)}(hhh](j})}(h wiphy_flagsh]j)}(henum wiphy_flagsh](j)}(hjh]henum}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMYubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMYubj)}(h wiphy_flagsh]j)}(hjh]h wiphy_flags}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMYubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhMYubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhMYhjhhubj)}(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.hhM`hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMYubeh}(h]h ](j8enumeh"]h$]h&]jj8jjjjjjjuh1jwhhhhhNhNubj)}(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&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMdhj ubj%)}(hhh](j*)}(hP``WIPHY_FLAG_SUPPORTS_EXT_KEK_KCK`` The device supports bigger kek and kck keys h](j0)}(h#``WIPHY_FLAG_SUPPORTS_EXT_KEK_KCK``h]j,)}(hj0h]hWIPHY_FLAG_SUPPORTS_EXT_KEK_KCK}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj.ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMghj*ubjJ)}(hhh]h)}(h+The device supports bigger kek and kck keysh]h+The device supports bigger kek and kck keys}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEhMghjFubah}(h]h ]h"]h$]h&]uh1jIhj*ubeh}(h]h ]h"]h$]h&]uh1j)hjEhMghj'ubj*)}(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](j0)}(h``WIPHY_FLAG_SUPPORTS_MLO``h]j,)}(hjih]hWIPHY_FLAG_SUPPORTS_MLO}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjgubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMmhjcubjJ)}(hhh]h)}(hThis is a temporary flag gating the MLO APIs, in order to not have them reachable in normal drivers, until we have complete feature/interface combinations/etc. advertisement. No driver should set this flag for now.h]hThis is a temporary flag gating the MLO APIs, in order to not have them reachable in normal drivers, until we have complete feature/interface combinations/etc. advertisement. No driver should set this flag for now.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMjhjubah}(h]h ]h"]h$]h&]uh1jIhjcubeh}(h]h ]h"]h$]h&]uh1j)hj~hMmhj'ubj*)}(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](j0)}(h``WIPHY_FLAG_SPLIT_SCAN_6GHZ``h]j,)}(hjh]hWIPHY_FLAG_SPLIT_SCAN_6GHZ}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMqhjubjJ)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMphjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMqhj'ubj*)}(hY``WIPHY_FLAG_NETNS_OK`` if not set, do not allow changing the netns of this wiphy at all h](j0)}(h``WIPHY_FLAG_NETNS_OK``h]j,)}(hjh]hWIPHY_FLAG_NETNS_OK}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMuhjubjJ)}(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.hhMthjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMuhj'ubj*)}(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](j0)}(h``WIPHY_FLAG_PS_ON_BY_DEFAULT``h]j,)}(hjh]hWIPHY_FLAG_PS_ON_BY_DEFAULT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM{hjubjJ)}(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}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMxhj-ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj,hM{hj'ubj*)}(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](j0)}(h``WIPHY_FLAG_4ADDR_AP``h]j,)}(hjQh]hWIPHY_FLAG_4ADDR_AP}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjOubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjKubjJ)}(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.}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM~hjgubah}(h]h ]h"]h$]h&]uh1jIhjKubeh}(h]h ]h"]h$]h&]uh1j)hjfhMhj'ubj*)}(hC``WIPHY_FLAG_4ADDR_STATION`` supports 4addr mode even as a station h](j0)}(h``WIPHY_FLAG_4ADDR_STATION``h]j,)}(hjh]hWIPHY_FLAG_4ADDR_STATION}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h%supports 4addr mode even as a stationh]h%supports 4addr mode even as a station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj'ubj*)}(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](j0)}(h$``WIPHY_FLAG_CONTROL_PORT_PROTOCOL``h]j,)}(hjh]h WIPHY_FLAG_CONTROL_PORT_PROTOCOL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj'ubj*)}(h6``WIPHY_FLAG_IBSS_RSN`` The device supports IBSS RSN. h](j0)}(h``WIPHY_FLAG_IBSS_RSN``h]j,)}(hjh]hWIPHY_FLAG_IBSS_RSN}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hThe device supports IBSS RSN.h]hThe device supports IBSS RSN.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hMhj'ubj*)}(hH``WIPHY_FLAG_DISABLE_WEXT`` disable wireless extensions for this device h](j0)}(h``WIPHY_FLAG_DISABLE_WEXT``h]j,)}(hj7 h]hWIPHY_FLAG_DISABLE_WEXT}(hj9 hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj5 ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj1 ubjJ)}(hhh]h)}(h+disable wireless extensions for this deviceh]h+disable wireless extensions for this device}(hjP hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjL hMhjM ubah}(h]h ]h"]h$]h&]uh1jIhj1 ubeh}(h]h ]h"]h$]h&]uh1j)hjL hMhj'ubj*)}(h``WIPHY_FLAG_MESH_AUTH`` The device supports mesh authentication by routing auth frames to userspace. See **NL80211_MESH_SETUP_USERSPACE_AUTH**. h](j0)}(h``WIPHY_FLAG_MESH_AUTH``h]j,)}(hjp h]hWIPHY_FLAG_MESH_AUTH}(hjr hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjn ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjj ubjJ)}(hhh]h)}(hwThe device supports mesh authentication by routing auth frames to userspace. See **NL80211_MESH_SETUP_USERSPACE_AUTH**.h](hQThe device supports mesh authentication by routing auth frames to userspace. See }(hj hhhNhNubj)}(h%**NL80211_MESH_SETUP_USERSPACE_AUTH**h]h!NL80211_MESH_SETUP_USERSPACE_AUTH}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj 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&]uh1jIhjj ubeh}(h]h ]h"]h$]h&]uh1j)hj hMhj'ubj*)}(hI``WIPHY_FLAG_SUPPORTS_EXT_KCK_32`` The device supports 32-byte KCK keys. h](j0)}(h"``WIPHY_FLAG_SUPPORTS_EXT_KCK_32``h]j,)}(hj h]hWIPHY_FLAG_SUPPORTS_EXT_KCK_32}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj ubjJ)}(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&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj hMhj'ubj*)}(hi``WIPHY_FLAG_SUPPORTS_NSTR_NONPRIMARY`` support connection to non-primary link of an NSTR mobile AP MLD. h](j0)}(h'``WIPHY_FLAG_SUPPORTS_NSTR_NONPRIMARY``h]j,)}(hj h]h#WIPHY_FLAG_SUPPORTS_NSTR_NONPRIMARY}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj ubjJ)}(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.h;hMhj !ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj !hMhj'ubj*)}(hU``WIPHY_FLAG_SUPPORTS_FW_ROAM`` The device supports roaming feature in the firmware. h](j0)}(h``WIPHY_FLAG_SUPPORTS_FW_ROAM``h]j,)}(hj/!h]hWIPHY_FLAG_SUPPORTS_FW_ROAM}(hj1!hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj-!ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj)!ubjJ)}(hhh]h)}(h4The device supports roaming feature in the firmware.h]h4The device supports roaming feature in the firmware.}(hjH!hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjE!ubah}(h]h ]h"]h$]h&]uh1jIhj)!ubeh}(h]h ]h"]h$]h&]uh1j)hjD!hMhj'ubj*)}(h9``WIPHY_FLAG_AP_UAPSD`` The device supports uapsd on AP. h](j0)}(h``WIPHY_FLAG_AP_UAPSD``h]j,)}(hji!h]hWIPHY_FLAG_AP_UAPSD}(hjk!hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjg!ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjc!ubjJ)}(hhh]h)}(h The device supports uapsd on AP.h]h The device supports uapsd on AP.}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~!hMhj!ubah}(h]h ]h"]h$]h&]uh1jIhjc!ubeh}(h]h ]h"]h$]h&]uh1j)hj~!hMhj'ubj*)}(hK``WIPHY_FLAG_SUPPORTS_TDLS`` The device supports TDLS (802.11z) operation. h](j0)}(h``WIPHY_FLAG_SUPPORTS_TDLS``h]j,)}(hj!h]hWIPHY_FLAG_SUPPORTS_TDLS}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj!ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj!ubjJ)}(hhh]h)}(h-The device supports TDLS (802.11z) operation.h]h-The device supports TDLS (802.11z) operation.}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hMhj!ubah}(h]h ]h"]h$]h&]uh1jIhj!ubeh}(h]h ]h"]h$]h&]uh1j)hj!hMhj'ubj*)}(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](j0)}(h"``WIPHY_FLAG_TDLS_EXTERNAL_SETUP``h]j,)}(hj!h]hWIPHY_FLAG_TDLS_EXTERNAL_SETUP}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj!ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj!ubjJ)}(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&]uh1jhj!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&]uh1jhj!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&]uh1jIhj!ubeh}(h]h ]h"]h$]h&]uh1j)hj!hMhj'ubj*)}(h4``WIPHY_FLAG_HAVE_AP_SME`` device integrates AP SME h](j0)}(h``WIPHY_FLAG_HAVE_AP_SME``h]j,)}(hj9"h]hWIPHY_FLAG_HAVE_AP_SME}(hj;"hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj7"ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj3"ubjJ)}(hhh]h)}(hdevice integrates AP SMEh]hdevice integrates AP SME}(hjR"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjN"hMhjO"ubah}(h]h ]h"]h$]h&]uh1jIhj3"ubeh}(h]h ]h"]h$]h&]uh1j)hjN"hMhj'ubj*)}(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](j0)}(h``WIPHY_FLAG_REPORTS_OBSS``h]j,)}(hjr"h]hWIPHY_FLAG_REPORTS_OBSS}(hjt"hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjp"ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjl"ubjJ)}(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&]uh1jIhjl"ubeh}(h]h ]h"]h$]h&]uh1j)hj"hMhj'ubj*)}(hq``WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD`` When operating as an AP, the device responds to probe-requests in hardware. h](j0)}(h$``WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD``h]j,)}(hj"h]h WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj"ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj"ubjJ)}(hhh]h)}(hKWhen operating as an AP, the device responds to probe-requests in hardware.h]hKWhen operating as an AP, the device responds to probe-requests in hardware.}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj"ubah}(h]h ]h"]h$]h&]uh1jIhj"ubeh}(h]h ]h"]h$]h&]uh1j)hj"hMhj'ubj*)}(hA``WIPHY_FLAG_OFFCHAN_TX`` Device supports direct off-channel TX. h](j0)}(h``WIPHY_FLAG_OFFCHAN_TX``h]j,)}(hj"h]hWIPHY_FLAG_OFFCHAN_TX}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj"ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj"ubjJ)}(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&]uh1jIhj"ubeh}(h]h ]h"]h$]h&]uh1j)hj"hMhj'ubj*)}(hM``WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL`` Device supports remain-on-channel call. h](j0)}(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&]uh1j+hj#ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj#ubjJ)}(hhh]h)}(h'Device supports remain-on-channel call.h]h'Device supports remain-on-channel call.}(hj8#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4#hMhj5#ubah}(h]h ]h"]h$]h&]uh1jIhj#ubeh}(h]h ]h"]h$]h&]uh1j)hj4#hMhj'ubj*)}(hL``WIPHY_FLAG_SUPPORTS_5_10_MHZ`` Device supports 5 MHz and 10 MHz channels. h](j0)}(h ``WIPHY_FLAG_SUPPORTS_5_10_MHZ``h]j,)}(hjX#h]hWIPHY_FLAG_SUPPORTS_5_10_MHZ}(hjZ#hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjV#ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjR#ubjJ)}(hhh]h)}(h*Device supports 5 MHz and 10 MHz channels.h]h*Device supports 5 MHz and 10 MHz channels.}(hjq#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjm#hMhjn#ubah}(h]h ]h"]h$]h&]uh1jIhjR#ubeh}(h]h ]h"]h$]h&]uh1j)hjm#hMhj'ubj*)}(hj``WIPHY_FLAG_HAS_CHANNEL_SWITCH`` Device supports channel switch in beaconing mode (AP, IBSS, Mesh, ...). h](j0)}(h!``WIPHY_FLAG_HAS_CHANNEL_SWITCH``h]j,)}(hj#h]hWIPHY_FLAG_HAS_CHANNEL_SWITCH}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj#ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj#ubjJ)}(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&]uh1jIhj#ubeh}(h]h ]h"]h$]h&]uh1j)hj#hMhj'ubj*)}(hl``WIPHY_FLAG_NOTIFY_REGDOM_BY_DRIVER`` The device could handle reg notify for NL80211_REGDOM_SET_BY_DRIVER. h](j0)}(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&]uh1j+hj#ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj#ubjJ)}(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&]uh1jIhj#ubeh}(h]h ]h"]h$]h&]uh1j)hj#hMhj'ubj*)}(h``WIPHY_FLAG_CHANNEL_CHANGE_ON_BEACON`` reg_call_notifier() is called if driver set this flag to update channels on beacon hints.h](j0)}(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&]uh1j+hj$ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj#ubjJ)}(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&]uh1jIhj#ubeh}(h]h ]h"]h$]h&]uh1j)hj$hMhj'ubeh}(h]h ]h"]h$]h&]uh1j$hj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js ieee80211_iface_limit (C struct)c.ieee80211_iface_limithNtauh1jfhhhhhNhNubjx)}(hhh](j})}(hieee80211_iface_limith]j)}(hstruct ieee80211_iface_limith](j)}(hjh]hstruct}(hj^$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZ$hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjl$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZ$hhhjk$hMubj)}(hieee80211_iface_limith]j)}(hjX$h]hieee80211_iface_limit}(hj~$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjz$ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjZ$hhhjk$hMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjV$hhhjk$hMubah}(h]jQ$ah ](jjeh"]h$]h&]jj)jhuh1j|hjk$hMhjS$hhubj)}(hhh]h)}(h limit on certain interface typesh]h limit on certain interface types}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj$hhubah}(h]h ]h"]h$]h&]uh1jhjS$hhhjk$hMubeh}(h]h ](j8structeh"]h$]h&]jj8jj$jj$jjjuh1jwhhhhhNhNubj)}(h**Definition**:: struct ieee80211_iface_limit { u16 max; u16 types; }; **Members** ``max`` maximum number of interfaces of these types ``types`` interface types (bits)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$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: )}(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&]jjuh1j9 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&]uh1jhj$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*)}(h4``max`` maximum number of interfaces of these types h](j0)}(h``max``h]j,)}(hj %h]hmax}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj %ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj%ubjJ)}(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&]uh1jIhj%ubeh}(h]h ]h"]h$]h&]uh1j)hj"%hMhj%ubj*)}(h ``types`` interface types (bits)h](j0)}(h ``types``h]j,)}(hjF%h]htypes}(hjH%hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjD%ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj@%ubjJ)}(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&]uh1jIhj@%ubeh}(h]h ]h"]h$]h&]uh1j)hj[%hMhj%ubeh}(h]h ]h"]h$]h&]uh1j$hj$ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js&ieee80211_iface_combination (C struct)c.ieee80211_iface_combinationhNtauh1jfhhhhhNhNubjx)}(hhh](j})}(hieee80211_iface_combinationh]j)}(h"struct ieee80211_iface_combinationh](j)}(hjh]hstruct}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%hhhj%hMubj)}(hieee80211_iface_combinationh]j)}(hj%h]hieee80211_iface_combination}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj%hhhj%hMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj%hhhj%hMubah}(h]j%ah ](jjeh"]h$]h&]jj)jhuh1j|hj%hMhj%hhubj)}(hhh]h)}(hpossible interface combinationh]hpossible interface combination}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj%hhubah}(h]h ]h"]h$]h&]uh1jhj%hhhj%hMubeh}(h]h ](j8structeh"]h$]h&]jj8jj%jj%jjjuh1jwhhhhhNhNubj)}(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&]uh1jhj&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&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj%ubh)}(h **Members**h]j)}(hj0&h]hMembers}(hj2&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.&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](j0)}(h ``limits``h]j,)}(hjO&h]hlimits}(hjQ&hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjM&ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjI&ubjJ)}(hhh]h)}(h$limits for the given interface typesh]h$limits for the given interface types}(hjh&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjd&hMhje&ubah}(h]h ]h"]h$]h&]uh1jIhjI&ubeh}(h]h ]h"]h$]h&]uh1j)hjd&hMhjF&ubj*)}(hF``num_different_channels`` can use up to this many different channels h](j0)}(h``num_different_channels``h]j,)}(hj&h]hnum_different_channels}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj&ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj&ubjJ)}(hhh]h)}(h*can use up to this many different channelsh]h*can use up to this many different channels}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMhj&ubah}(h]h ]h"]h$]h&]uh1jIhj&ubeh}(h]h ]h"]h$]h&]uh1j)hj&hMhjF&ubj*)}(hO``max_interfaces`` maximum number of interfaces in total allowed in this group h](j0)}(h``max_interfaces``h]j,)}(hj&h]hmax_interfaces}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj&ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj&ubjJ)}(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&hM hj&ubah}(h]h ]h"]h$]h&]uh1jIhj&ubeh}(h]h ]h"]h$]h&]uh1j)hj&hM hjF&ubj*)}(h#``n_limits`` number of limitations h](j0)}(h ``n_limits``h]j,)}(hj&h]hn_limits}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj&ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj&ubjJ)}(hhh]h)}(hnumber of limitationsh]hnumber of limitations}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hMhj'ubah}(h]h ]h"]h$]h&]uh1jIhj&ubeh}(h]h ]h"]h$]h&]uh1j)hj'hMhjF&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](j0)}(h``beacon_int_infra_match``h]j,)}(hj3'h]hbeacon_int_infra_match}(hj5'hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj1'ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj-'ubjJ)}(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.}(hjL'hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjI'ubah}(h]h ]h"]h$]h&]uh1jIhj-'ubeh}(h]h ]h"]h$]h&]uh1j)hjH'hMhjF&ubj*)}(hO``radar_detect_widths`` bitmap of channel widths supported for radar detection h](j0)}(h``radar_detect_widths``h]j,)}(hjm'h]hradar_detect_widths}(hjo'hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjk'ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjg'ubjJ)}(hhh]h)}(h6bitmap of channel widths supported for radar detectionh]h6bitmap of channel widths supported for radar detection}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hMhj'ubah}(h]h ]h"]h$]h&]uh1jIhjg'ubeh}(h]h ]h"]h$]h&]uh1j)hj'hMhjF&ubj*)}(hI``radar_detect_regions`` bitmap of regions supported for radar detection h](j0)}(h``radar_detect_regions``h]j,)}(hj'h]hradar_detect_regions}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj'ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM"hj'ubjJ)}(hhh]h)}(h/bitmap of regions supported for radar detectionh]h/bitmap of regions supported for radar detection}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hM"hj'ubah}(h]h ]h"]h$]h&]uh1jIhj'ubeh}(h]h ]h"]h$]h&]uh1j)hj'hM"hjF&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](j0)}(h``beacon_int_min_gcd``h]j,)}(hj'h]hbeacon_int_min_gcd}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj'ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM.hj'ubjJ)}(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](j0)}(h= 0h]h= 0}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM*hj (ubjJ)}(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.hhM+hj(ubah}(h]h ]h"]h$]h&]uh1jIhj (ubeh}(h]h ]h"]h$]h&]uh1j)hj(hM*hj(ubj*)}(h> 0 any beacon interval for the interface part of this combination AND GCD of all beacon intervals from beaconing interfaces of this combination must be greater or equal to this value.h](j0)}(h> 0h]h> 0}(hj?(hhhNhNubah}(h]h ]h"]h$]h&]uh1j/hj'hM.hj;(ubjJ)}(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.}(hjP(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM-hjM(ubah}(h]h ]h"]h$]h&]uh1jIhj;(ubeh}(h]h ]h"]h$]h&]uh1j)hj'hM.hj(ubeh}(h]h ]h"]h$]h&]uh1j$hj'ubeh}(h]h ]h"]h$]h&]uh1jIhj'ubeh}(h]h ]h"]h$]h&]uh1j)hj'hM.hjF&ubeh}(h]h ]h"]h$]h&]uh1j$hj%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hj(h]h Description}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM2hhhhubh)}(hWith this structure the driver can describe which interface combinations it supports concurrently. When set in a struct wiphy_radio, the combinations refer to combinations of interfaces currently active on that radio.h]hWith this structure the driver can describe which interface combinations it supports concurrently. When set in a struct wiphy_radio, the combinations refer to combinations of interfaces currently active on that radio.}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhhhhubh)}(h **Examples**h]j)}(hj(h]hExamples}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhhhhubhenumerated_list)}(hhh](h list_item)}(hXAllow #STA <= 1, #AP <= 1, matching BI, channels = 1, 2 total: .. code-block:: c struct ieee80211_iface_limit limits1[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 1, .types = BIT(NL80211_IFTYPE_AP), }, }; struct ieee80211_iface_combination combination1 = { .limits = limits1, .n_limits = ARRAY_SIZE(limits1), .max_interfaces = 2, .beacon_int_infra_match = true, }; h](h)}(h>Allow #STA <= 1, #AP <= 1, matching BI, channels = 1, 2 total:h]h>Allow #STA <= 1, #AP <= 1, matching BI, channels = 1, 2 total:}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(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&]jjforcelanguagej8highlight_args}uh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(ubeh}(h]h ]h"]h$]h&]uh1j(hj(ubj()}(hXAllow #{AP, P2P-GO} <= 8, channels = 1, 8 total: .. code-block:: c struct ieee80211_iface_limit limits2[] = { { .max = 8, .types = BIT(NL80211_IFTYPE_AP) | BIT(NL80211_IFTYPE_P2P_GO), }, }; struct ieee80211_iface_combination combination2 = { .limits = limits2, .n_limits = ARRAY_SIZE(limits2), .max_interfaces = 8, .num_different_channels = 1, }; h](h)}(h0Allow #{AP, P2P-GO} <= 8, channels = 1, 8 total:h]h0Allow #{AP, P2P-GO} <= 8, channels = 1, 8 total:}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(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(j8j(}uh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(ubeh}(h]h ]h"]h$]h&]uh1j(hj(ubj()}(hX]Allow #STA <= 1, #{P2P-client,P2P-GO} <= 3 on two channels, 4 total. This allows for an infrastructure connection and three P2P connections. .. code-block:: c struct ieee80211_iface_limit limits3[] = { { .max = 1, .types = BIT(NL80211_IFTYPE_STATION), }, { .max = 3, .types = BIT(NL80211_IFTYPE_P2P_GO) | BIT(NL80211_IFTYPE_P2P_CLIENT), }, }; struct ieee80211_iface_combination combination3 = { .limits = limits3, .n_limits = ARRAY_SIZE(limits3), .max_interfaces = 4, .num_different_channels = 2, }; h](h)}(hDAllow #STA <= 1, #{P2P-client,P2P-GO} <= 3 on two channels, 4 total.h]hDAllow #STA <= 1, #{P2P-client,P2P-GO} <= 3 on two channels, 4 total.}(hj))hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj%)ubh)}(hGThis allows for an infrastructure connection and three P2P connections.h]hGThis allows for an infrastructure connection and three P2P connections.}(hj8)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, };}hjG)sbah}(h]h ]h"]h$]h&]jjj(j(j8j(}uh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj%)ubeh}(h]h ]h"]h$]h&]uh1j(hj(ubeh}(h]h ]h"]h$]h&]enumtypearabicprefixhsuffix.uh1j(hhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jswiphy (C struct)c.wiphyhNtauh1jfhhhhhNhNubjx)}(hhh](j})}(hwiphyh]j)}(h struct wiphyh](j)}(hjh]hstruct}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj})hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj})hhhj)hMubj)}(hwiphyh]j)}(hj{)h]hwiphy}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj})hhhj)hMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjy)hhhj)hMubah}(h]jt)ah ](jjeh"]h$]h&]jj)jhuh1j|hj)hMhjv)hhubj)}(hhh]h)}(hwireless hardware descriptionh]hwireless hardware description}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj)hhubah}(h]h ]h"]h$]h&]uh1jhjv)hhhj)hMubeh}(h]h ](j8structeh"]h$]h&]jj8jj)jj)jjjuh1jwhhhhhNhNubj)}(hX=**Definition**:: struct wiphy { struct mutex mtx; u8 perm_addr[ETH_ALEN]; u8 addr_mask[ETH_ALEN]; struct mac_address *addresses; const struct ieee80211_txrx_stypes *mgmt_stypes; const struct ieee80211_iface_combination *iface_combinations; int n_iface_combinations; u16 software_iftypes; u16 n_addresses; u16 interface_modes; u16 max_acl_mac_addrs; u32 flags, regulatory_flags, features; u8 ext_features[DIV_ROUND_UP(NUM_NL80211_EXT_FEATURES, 8)]; u32 ap_sme_capa; enum cfg80211_signal_type signal_type; int bss_priv_size; u8 max_scan_ssids; u8 max_sched_scan_reqs; u8 max_sched_scan_ssids; u8 max_match_sets; u16 max_scan_ie_len; u16 max_sched_scan_ie_len; u32 max_sched_scan_plans; u32 max_sched_scan_plan_interval; u32 max_sched_scan_plan_iterations; int n_cipher_suites; const u32 *cipher_suites; int n_akm_suites; const u32 *akm_suites; const struct wiphy_iftype_akm_suites *iftype_akm_suites; unsigned int num_iftype_akm_suites; u8 retry_short; u8 retry_long; u32 frag_threshold; u32 rts_threshold; u8 coverage_class; char fw_version[ETHTOOL_FWVERS_LEN]; u32 hw_version; #ifdef CONFIG_PM; const struct wiphy_wowlan_support *wowlan; struct cfg80211_wowlan *wowlan_config; #endif; u16 max_remain_on_channel_duration; u8 max_num_pmkids; u32 available_antennas_tx; u32 available_antennas_rx; u32 probe_resp_offload; const u8 *extended_capabilities, *extended_capabilities_mask; u8 extended_capabilities_len; const struct wiphy_iftype_ext_capab *iftype_ext_capab; unsigned int num_iftype_ext_capab; const void *privid; struct ieee80211_supported_band *bands[NUM_NL80211_BANDS]; void (*reg_notifier)(struct wiphy *wiphy, struct regulatory_request *request); struct wiphy_radio_cfg *radio_cfg; const struct ieee80211_regdomain *regd; struct device dev; bool registered; struct dentry *debugfsdir; const struct ieee80211_ht_cap *ht_capa_mod_mask; const struct ieee80211_vht_cap *vht_capa_mod_mask; struct list_head wdev_list; possible_net_t _net; #ifdef CONFIG_CFG80211_WEXT; const struct iw_handler_def *wext; #endif; const struct wiphy_coalesce_support *coalesce; const struct wiphy_vendor_command *vendor_commands; const struct nl80211_vendor_cmd_info *vendor_events; int n_vendor_commands, n_vendor_events; u16 max_ap_assoc_sta; u8 max_num_csa_counters; u32 bss_param_support; u32 bss_select_support; u8 nan_supported_bands; struct wiphy_nan_capa nan_capa; u32 txq_limit; u32 txq_memory_limit; u32 txq_quantum; unsigned long tx_queue_len; u8 support_mbssid:1, support_only_he_mbssid:1; const struct cfg80211_pmsr_capabilities *pmsr_capa; struct { u64 peer, vif; u8 max_retry; } tid_config_support; u8 max_data_retry_count; const struct cfg80211_sar_capa *sar_capa; struct rfkill *rfkill; u8 mbssid_max_interfaces; u8 ema_max_profile_periodicity; u16 max_num_akm_suites; u16 hw_timestamp_max_peers; int n_radio; const struct wiphy_radio *radio; char priv[]; }; **Members** ``mtx`` mutex for the data (structures) of this device ``perm_addr`` permanent MAC address of this device ``addr_mask`` If the device supports multiple MAC addresses by masking, set this to a mask with variable bits set to 1, e.g. if the last four bits are variable then set it to 00-00-00-00-00-0f. The actual variable bits shall be determined by the interfaces added, with interfaces not matching the mask being rejected to be brought up. ``addresses`` If the device has more than one address, set this pointer to a list of addresses (6 bytes each). The first one will be used by default for perm_addr. In this case, the mask should be set to all-zeroes. In this case it is assumed that the device can handle the same number of arbitrary MAC addresses. ``mgmt_stypes`` bitmasks of frame subtypes that can be subscribed to or transmitted through nl80211, points to an array indexed by interface type ``iface_combinations`` Valid interface combinations array, should not list single interface types. ``n_iface_combinations`` number of entries in **iface_combinations** array. ``software_iftypes`` bitmask of software interface types, these are not subject to any restrictions since they are purely managed in SW. ``n_addresses`` number of addresses in **addresses**. ``interface_modes`` bitmask of interfaces types valid for this wiphy, must be set by driver ``max_acl_mac_addrs`` Maximum number of MAC addresses that the device supports for ACL. ``flags`` wiphy flags, see :c:type:`enum wiphy_flags ` ``regulatory_flags`` wiphy regulatory flags, see :c:type:`enum ieee80211_regulatory_flags ` ``features`` features advertised to nl80211, see :c:type:`enum nl80211_feature_flags `. ``ext_features`` extended features advertised to nl80211, see :c:type:`enum nl80211_ext_feature_index `. ``ap_sme_capa`` AP SME capabilities, flags from :c:type:`enum nl80211_ap_sme_features `. ``signal_type`` signal type reported in :c:type:`struct cfg80211_bss `. ``bss_priv_size`` each BSS struct has private data allocated with it, this variable determines its size ``max_scan_ssids`` maximum number of SSIDs the device can scan for in any given scan ``max_sched_scan_reqs`` maximum number of scheduled scan requests that the device can run concurrently. ``max_sched_scan_ssids`` maximum number of SSIDs the device can scan for in any given scheduled scan ``max_match_sets`` maximum number of match sets the device can handle when performing a scheduled scan, 0 if filtering is not supported. ``max_scan_ie_len`` maximum length of user-controlled IEs device can add to probe request frames transmitted during a scan, must not include fixed IEs like supported rates ``max_sched_scan_ie_len`` same as max_scan_ie_len, but for scheduled scans ``max_sched_scan_plans`` maximum number of scan plans (scan interval and number of iterations) for scheduled scan supported by the device. ``max_sched_scan_plan_interval`` maximum interval (in seconds) for a single scan plan supported by the device. ``max_sched_scan_plan_iterations`` maximum number of iterations for a single scan plan supported by the device. ``n_cipher_suites`` number of supported cipher suites ``cipher_suites`` supported cipher suites ``n_akm_suites`` number of supported AKM suites ``akm_suites`` supported AKM suites. These are the default AKMs supported if the supported AKMs not advertized for a specific interface type in iftype_akm_suites. ``iftype_akm_suites`` array of supported akm suites info per interface type. Note that the bits in **iftypes_mask** inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_akm_suites). ``num_iftype_akm_suites`` number of interface types for which supported akm suites are specified separately. ``retry_short`` Retry limit for short frames (dot11ShortRetryLimit) ``retry_long`` Retry limit for long frames (dot11LongRetryLimit) ``frag_threshold`` Fragmentation threshold (dot11FragmentationThreshold); -1 = fragmentation disabled, only odd values >= 256 used ``rts_threshold`` RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabled ``coverage_class`` current coverage class ``fw_version`` firmware version for ethtool reporting ``hw_version`` hardware version for ethtool reporting ``wowlan`` WoWLAN support information ``wowlan_config`` current WoWLAN configuration; this should usually not be used since access to it is necessarily racy, use the parameter passed to the suspend() operation instead. ``max_remain_on_channel_duration`` Maximum time a remain-on-channel operation may request, if implemented. ``max_num_pmkids`` maximum number of PMKIDs supported by device ``available_antennas_tx`` bitmap of antennas which are available to be configured as TX antennas. Antenna configuration commands will be rejected unless this or **available_antennas_rx** is set. ``available_antennas_rx`` bitmap of antennas which are available to be configured as RX antennas. Antenna configuration commands will be rejected unless this or **available_antennas_tx** is set. ``probe_resp_offload`` Bitmap of supported protocols for probe response offloading. See :c:type:`enum nl80211_probe_resp_offload_support_attr `. Only valid when the wiphy flag **WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD** is set. ``extended_capabilities`` extended capabilities supported by the driver, additional capabilities might be supported by userspace; these are the 802.11 extended capabilities ("Extended Capabilities element") and are in the same format as in the information element. See 802.11-2012 8.4.2.29 for the defined fields. These are the default extended capabilities to be used if the capabilities are not specified for a specific interface type in iftype_ext_capab. ``extended_capabilities_mask`` mask of the valid values ``extended_capabilities_len`` length of the extended capabilities ``iftype_ext_capab`` array of extended capabilities per interface type ``num_iftype_ext_capab`` number of interface types for which extended capabilities are specified separately. ``privid`` a pointer that drivers can use to identify if an arbitrary wiphy is theirs, e.g. in global notifiers ``bands`` information about bands/channels supported by this device ``reg_notifier`` the driver's regulatory notification callback, note that if your driver uses wiphy_apply_custom_regulatory() the reg_notifier's request can be passed as NULL ``radio_cfg`` configuration of radios belonging to a muli-radio wiphy. This struct contains a list of all radio specific attributes and should be used only for multi-radio wiphy. ``regd`` the driver's regulatory domain, if one was requested via the regulatory_hint() API. This can be used by the driver on the reg_notifier() if it chooses to ignore future regulatory domain changes caused by other drivers. ``dev`` (virtual) struct device for this wiphy. The item in /sys/class/ieee80211/ points to this. You need use set_wiphy_dev() (see below). ``registered`` protects ->resume and ->suspend sysfs callbacks against unregister hardware ``debugfsdir`` debugfs directory used for this wiphy (ieee80211/). It will be renamed automatically on wiphy renames ``ht_capa_mod_mask`` Specify what ht_cap values can be over-ridden. If null, then none can be over-ridden. ``vht_capa_mod_mask`` Specify what VHT capabilities can be over-ridden. If null, then none can be over-ridden. ``wdev_list`` the list of associated (virtual) interfaces; this list must not be modified by the driver, but can be read with RTNL/RCU protection. ``_net`` the network namespace this wiphy currently lives in ``wext`` wireless extension handlers ``coalesce`` packet coalescing support information ``vendor_commands`` array of vendor commands supported by the hardware ``vendor_events`` array of vendor events supported by the hardware ``n_vendor_commands`` number of vendor commands ``n_vendor_events`` number of vendor events ``max_ap_assoc_sta`` maximum number of associated stations supported in AP mode (including P2P GO) or 0 to indicate no such limit is advertised. The driver is allowed to advertise a theoretical limit that it can reach in some cases, but may not always reach. ``max_num_csa_counters`` Number of supported csa_counters in beacons and probe responses. This value should be set if the driver wishes to limit the number of csa counters. Default (0) means infinite. ``bss_param_support`` bitmask indicating which bss_parameters as defined in :c:type:`struct bss_parameters ` the driver can actually handle in the .change_bss() callback. The bit positions are defined in :c:type:`enum wiphy_bss_param_flags `. ``bss_select_support`` bitmask indicating the BSS selection criteria supported by the driver in the .connect() callback. The bit position maps to the attribute indices defined in :c:type:`enum nl80211_bss_select_attr `. ``nan_supported_bands`` bands supported by the device in NAN mode, a bitmap of :c:type:`enum nl80211_band ` values. For instance, for NL80211_BAND_2GHZ, bit 0 would be set (i.e. BIT(NL80211_BAND_2GHZ)). ``nan_capa`` NAN capabilities ``txq_limit`` configuration of internal TX queue frame limit ``txq_memory_limit`` configuration internal TX queue memory limit ``txq_quantum`` configuration of internal TX queue scheduler quantum ``tx_queue_len`` allow setting transmit queue len for drivers not using wake_tx_queue ``support_mbssid`` can HW support association with nontransmitted AP ``support_only_he_mbssid`` don't parse MBSSID elements if it is not HE AP, in order to avoid compatibility issues. **support_mbssid** must be set for this to have any effect. ``pmsr_capa`` peer measurement capabilities ``tid_config_support`` describes the per-TID config support that the device has ``tid_config_support.peer`` bitmap of attributes (configurations) supported by the driver for each peer ``tid_config_support.vif`` bitmap of attributes (configurations) supported by the driver for each vif ``tid_config_support.max_retry`` maximum supported retry count for long/short retry configuration ``max_data_retry_count`` maximum supported per TID retry count for configuration through the ``NL80211_TID_CONFIG_ATTR_RETRY_SHORT`` and ``NL80211_TID_CONFIG_ATTR_RETRY_LONG`` attributes ``sar_capa`` SAR control capabilities ``rfkill`` a pointer to the rfkill structure ``mbssid_max_interfaces`` maximum number of interfaces supported by the driver in a multiple BSSID set. This field must be set to a non-zero value by the driver to advertise MBSSID support. ``ema_max_profile_periodicity`` maximum profile periodicity supported by the driver. Setting this field to a non-zero value indicates that the driver supports enhanced multi-BSSID advertisements (EMA AP). ``max_num_akm_suites`` maximum number of AKM suites allowed for configuration through ``NL80211_CMD_CONNECT``, ``NL80211_CMD_ASSOCIATE`` and ``NL80211_CMD_START_AP``. Set to NL80211_MAX_NR_AKM_SUITES if not set by driver. If set by driver minimum allowed value is NL80211_MAX_NR_AKM_SUITES in order to avoid compatibility issues with legacy userspace and maximum allowed value is CFG80211_MAX_NUM_AKM_SUITES. ``hw_timestamp_max_peers`` maximum number of peers that the driver supports enabling HW timestamping for concurrently. Setting this field to a non-zero value indicates that the driver supports HW timestamping. A value of ``CFG80211_HW_TIMESTAMP_ALL_PEERS`` indicates the driver supports enabling HW timestamping for all peers (i.e. no need to specify a mac address). ``n_radio`` number of radios ``radio`` radios belonging to this wiphy ``priv`` driver private data (sized according to wiphy_new() parameter)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubh:}(hj)hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj)ubj: )}(hX struct wiphy { struct mutex mtx; u8 perm_addr[ETH_ALEN]; u8 addr_mask[ETH_ALEN]; struct mac_address *addresses; const struct ieee80211_txrx_stypes *mgmt_stypes; const struct ieee80211_iface_combination *iface_combinations; int n_iface_combinations; u16 software_iftypes; u16 n_addresses; u16 interface_modes; u16 max_acl_mac_addrs; u32 flags, regulatory_flags, features; u8 ext_features[DIV_ROUND_UP(NUM_NL80211_EXT_FEATURES, 8)]; u32 ap_sme_capa; enum cfg80211_signal_type signal_type; int bss_priv_size; u8 max_scan_ssids; u8 max_sched_scan_reqs; u8 max_sched_scan_ssids; u8 max_match_sets; u16 max_scan_ie_len; u16 max_sched_scan_ie_len; u32 max_sched_scan_plans; u32 max_sched_scan_plan_interval; u32 max_sched_scan_plan_iterations; int n_cipher_suites; const u32 *cipher_suites; int n_akm_suites; const u32 *akm_suites; const struct wiphy_iftype_akm_suites *iftype_akm_suites; unsigned int num_iftype_akm_suites; u8 retry_short; u8 retry_long; u32 frag_threshold; u32 rts_threshold; u8 coverage_class; char fw_version[ETHTOOL_FWVERS_LEN]; u32 hw_version; #ifdef CONFIG_PM; const struct wiphy_wowlan_support *wowlan; struct cfg80211_wowlan *wowlan_config; #endif; u16 max_remain_on_channel_duration; u8 max_num_pmkids; u32 available_antennas_tx; u32 available_antennas_rx; u32 probe_resp_offload; const u8 *extended_capabilities, *extended_capabilities_mask; u8 extended_capabilities_len; const struct wiphy_iftype_ext_capab *iftype_ext_capab; unsigned int num_iftype_ext_capab; const void *privid; struct ieee80211_supported_band *bands[NUM_NL80211_BANDS]; void (*reg_notifier)(struct wiphy *wiphy, struct regulatory_request *request); struct wiphy_radio_cfg *radio_cfg; const struct ieee80211_regdomain *regd; struct device dev; bool registered; struct dentry *debugfsdir; const struct ieee80211_ht_cap *ht_capa_mod_mask; const struct ieee80211_vht_cap *vht_capa_mod_mask; struct list_head wdev_list; possible_net_t _net; #ifdef CONFIG_CFG80211_WEXT; const struct iw_handler_def *wext; #endif; const struct wiphy_coalesce_support *coalesce; const struct wiphy_vendor_command *vendor_commands; const struct nl80211_vendor_cmd_info *vendor_events; int n_vendor_commands, n_vendor_events; u16 max_ap_assoc_sta; u8 max_num_csa_counters; u32 bss_param_support; u32 bss_select_support; u8 nan_supported_bands; struct wiphy_nan_capa nan_capa; u32 txq_limit; u32 txq_memory_limit; u32 txq_quantum; unsigned long tx_queue_len; u8 support_mbssid:1, support_only_he_mbssid:1; const struct cfg80211_pmsr_capabilities *pmsr_capa; struct { u64 peer, vif; u8 max_retry; } tid_config_support; u8 max_data_retry_count; const struct cfg80211_sar_capa *sar_capa; struct rfkill *rfkill; u8 mbssid_max_interfaces; u8 ema_max_profile_periodicity; u16 max_num_akm_suites; u16 hw_timestamp_max_peers; int n_radio; const struct wiphy_radio *radio; char priv[]; };h]hX struct wiphy { struct mutex mtx; u8 perm_addr[ETH_ALEN]; u8 addr_mask[ETH_ALEN]; struct mac_address *addresses; const struct ieee80211_txrx_stypes *mgmt_stypes; const struct ieee80211_iface_combination *iface_combinations; int n_iface_combinations; u16 software_iftypes; u16 n_addresses; u16 interface_modes; u16 max_acl_mac_addrs; u32 flags, regulatory_flags, features; u8 ext_features[DIV_ROUND_UP(NUM_NL80211_EXT_FEATURES, 8)]; u32 ap_sme_capa; enum cfg80211_signal_type signal_type; int bss_priv_size; u8 max_scan_ssids; u8 max_sched_scan_reqs; u8 max_sched_scan_ssids; u8 max_match_sets; u16 max_scan_ie_len; u16 max_sched_scan_ie_len; u32 max_sched_scan_plans; u32 max_sched_scan_plan_interval; u32 max_sched_scan_plan_iterations; int n_cipher_suites; const u32 *cipher_suites; int n_akm_suites; const u32 *akm_suites; const struct wiphy_iftype_akm_suites *iftype_akm_suites; unsigned int num_iftype_akm_suites; u8 retry_short; u8 retry_long; u32 frag_threshold; u32 rts_threshold; u8 coverage_class; char fw_version[ETHTOOL_FWVERS_LEN]; u32 hw_version; #ifdef CONFIG_PM; const struct wiphy_wowlan_support *wowlan; struct cfg80211_wowlan *wowlan_config; #endif; u16 max_remain_on_channel_duration; u8 max_num_pmkids; u32 available_antennas_tx; u32 available_antennas_rx; u32 probe_resp_offload; const u8 *extended_capabilities, *extended_capabilities_mask; u8 extended_capabilities_len; const struct wiphy_iftype_ext_capab *iftype_ext_capab; unsigned int num_iftype_ext_capab; const void *privid; struct ieee80211_supported_band *bands[NUM_NL80211_BANDS]; void (*reg_notifier)(struct wiphy *wiphy, struct regulatory_request *request); struct wiphy_radio_cfg *radio_cfg; const struct ieee80211_regdomain *regd; struct device dev; bool registered; struct dentry *debugfsdir; const struct ieee80211_ht_cap *ht_capa_mod_mask; const struct ieee80211_vht_cap *vht_capa_mod_mask; struct list_head wdev_list; possible_net_t _net; #ifdef CONFIG_CFG80211_WEXT; const struct iw_handler_def *wext; #endif; const struct wiphy_coalesce_support *coalesce; const struct wiphy_vendor_command *vendor_commands; const struct nl80211_vendor_cmd_info *vendor_events; int n_vendor_commands, n_vendor_events; u16 max_ap_assoc_sta; u8 max_num_csa_counters; u32 bss_param_support; u32 bss_select_support; u8 nan_supported_bands; struct wiphy_nan_capa nan_capa; u32 txq_limit; u32 txq_memory_limit; u32 txq_quantum; unsigned long tx_queue_len; u8 support_mbssid:1, support_only_he_mbssid:1; const struct cfg80211_pmsr_capabilities *pmsr_capa; struct { u64 peer, vif; u8 max_retry; } tid_config_support; u8 max_data_retry_count; const struct cfg80211_sar_capa *sar_capa; struct rfkill *rfkill; u8 mbssid_max_interfaces; u8 ema_max_profile_periodicity; u16 max_num_akm_suites; u16 hw_timestamp_max_peers; int n_radio; const struct wiphy_radio *radio; char priv[]; };}hj*sbah}(h]h ]h"]h$]h&]jjuh1j9 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&]uh1jhj*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](j0)}(h``mtx``h]j,)}(hj0*h]hmtx}(hj2*hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj.*ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj**ubjJ)}(hhh]h)}(h.mutex for the data (structures) of this deviceh]h.mutex for the data (structures) of this device}(hjI*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjE*hMhjF*ubah}(h]h ]h"]h$]h&]uh1jIhj**ubeh}(h]h ]h"]h$]h&]uh1j)hjE*hMhj'*ubj*)}(h3``perm_addr`` permanent MAC address of this device h](j0)}(h ``perm_addr``h]j,)}(hji*h]h perm_addr}(hjk*hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjg*ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjc*ubjJ)}(hhh]h)}(h$permanent MAC address of this deviceh]h$permanent MAC address of this device}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~*hMhj*ubah}(h]h ]h"]h$]h&]uh1jIhjc*ubeh}(h]h ]h"]h$]h&]uh1j)hj~*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](j0)}(h ``addr_mask``h]j,)}(hj*h]h addr_mask}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj*ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj*ubjJ)}(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.}(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&]uh1jIhj*ubeh}(h]h ]h"]h$]h&]uh1j)hj*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](j0)}(h ``addresses``h]j,)}(hj*h]h addresses}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj*ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj*ubjJ)}(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&]uh1jIhj*ubeh}(h]h ]h"]h$]h&]uh1j)hj*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](j0)}(h``mgmt_stypes``h]j,)}(hj+h]h mgmt_stypes}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj+ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj+ubjJ)}(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&]uh1jIhj+ubeh}(h]h ]h"]h$]h&]uh1j)hj++hMhj'*ubj*)}(hc``iface_combinations`` Valid interface combinations array, should not list single interface types. h](j0)}(h``iface_combinations``h]j,)}(hjP+h]hiface_combinations}(hjR+hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjN+ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjJ+ubjJ)}(hhh]h)}(hKValid interface combinations array, should not list single interface types.h]hKValid interface combinations array, should not list single interface types.}(hji+hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjf+ubah}(h]h ]h"]h$]h&]uh1jIhjJ+ubeh}(h]h ]h"]h$]h&]uh1j)hje+hMhj'*ubj*)}(hL``n_iface_combinations`` number of entries in **iface_combinations** array. h](j0)}(h``n_iface_combinations``h]j,)}(hj+h]hn_iface_combinations}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj+ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj+ubjJ)}(hhh]h)}(h2number of entries in **iface_combinations** array.h](hnumber of entries in }(hj+hhhNhNubj)}(h**iface_combinations**h]hiface_combinations}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubh array.}(hj+hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj+hMhj+ubah}(h]h ]h"]h$]h&]uh1jIhj+ubeh}(h]h ]h"]h$]h&]uh1j)hj+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](j0)}(h``software_iftypes``h]j,)}(hj+h]hsoftware_iftypes}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj+ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj+ubjJ)}(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&]uh1jIhj+ubeh}(h]h ]h"]h$]h&]uh1j)hj+hMhj'*ubj*)}(h6``n_addresses`` number of addresses in **addresses**. h](j0)}(h``n_addresses``h]j,)}(hj,h]h n_addresses}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ,ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj ,ubjJ)}(hhh]h)}(h%number of addresses in **addresses**.h](hnumber of addresses in }(hj(,hhhNhNubj)}(h **addresses**h]h addresses}(hj0,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(,ubh.}(hj(,hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj$,hMhj%,ubah}(h]h ]h"]h$]h&]uh1jIhj ,ubeh}(h]h ]h"]h$]h&]uh1j)hj$,hMhj'*ubj*)}(h\``interface_modes`` bitmask of interfaces types valid for this wiphy, must be set by driver h](j0)}(h``interface_modes``h]j,)}(hjZ,h]hinterface_modes}(hj\,hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjX,ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjT,ubjJ)}(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}(hjs,hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjp,ubah}(h]h ]h"]h$]h&]uh1jIhjT,ubeh}(h]h ]h"]h$]h&]uh1j)hjo,hMhj'*ubj*)}(hX``max_acl_mac_addrs`` Maximum number of MAC addresses that the device supports for ACL. h](j0)}(h``max_acl_mac_addrs``h]j,)}(hj,h]hmax_acl_mac_addrs}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj,ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM%hj,ubjJ)}(hhh]h)}(hAMaximum number of MAC addresses that the device supports for ACL.h]hAMaximum number of MAC addresses that the device supports for ACL.}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$hj,ubah}(h]h ]h"]h$]h&]uh1jIhj,ubeh}(h]h ]h"]h$]h&]uh1j)hj,hM%hj'*ubj*)}(hD``flags`` wiphy flags, see :c:type:`enum wiphy_flags ` h](j0)}(h ``flags``h]j,)}(hj,h]hflags}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj,ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj,ubjJ)}(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 ](j7j8c-typeeh"]h$]h&]uh1j+hj,ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJ wiphy_flagsuh1hhj,hMhj,ubeh}(h]h ]h"]h$]h&]uh1hhj,hMhj,ubah}(h]h ]h"]h$]h&]uh1jIhj,ubeh}(h]h ]h"]h$]h&]uh1j)hj,hMhj'*ubj*)}(hx``regulatory_flags`` wiphy regulatory flags, see :c:type:`enum ieee80211_regulatory_flags ` h](j0)}(h``regulatory_flags``h]j,)}(hj&-h]hregulatory_flags}(hj(-hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj$-ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj -ubjJ)}(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,)}(hjI-h]henum ieee80211_regulatory_flags}(hjK-hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjG-ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJieee80211_regulatory_flagsuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj?-ubeh}(h]h ]h"]h$]h&]uh1hhjf-hMhj<-ubah}(h]h ]h"]h$]h&]uh1jIhj -ubeh}(h]h ]h"]h$]h&]uh1j)hj;-hMhj'*ubj*)}(ho``features`` features advertised to nl80211, see :c:type:`enum nl80211_feature_flags `. h](j0)}(h ``features``h]j,)}(hj-h]hfeatures}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj}-ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjy-ubjJ)}(hhh]h)}(hafeatures advertised to nl80211, see :c:type:`enum nl80211_feature_flags `.h](h$features advertised to nl80211, see }(hj-hhhNhNubh)}(h<:c:type:`enum nl80211_feature_flags `h]j,)}(hj-h]henum nl80211_feature_flags}(hj-hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj-ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_feature_flagsuh1hhj-hMhj-ubh.}(hj-hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj-hMhj-ubah}(h]h ]h"]h$]h&]uh1jIhjy-ubeh}(h]h ]h"]h$]h&]uh1j)hj-hMhj'*ubj*)}(h``ext_features`` extended features advertised to nl80211, see :c:type:`enum nl80211_ext_feature_index `. h](j0)}(h``ext_features``h]j,)}(hj-h]h ext_features}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj-ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj-ubjJ)}(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 ](j7j8c-typeeh"]h$]h&]uh1j+hj-ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_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&]uh1jIhj-ubeh}(h]h ]h"]h$]h&]uh1j)hj-hMhj'*ubj*)}(hr``ap_sme_capa`` AP SME capabilities, flags from :c:type:`enum nl80211_ap_sme_features `. h](j0)}(h``ap_sme_capa``h]j,)}(hj8.h]h ap_sme_capa}(hj:.hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6.ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2.ubjJ)}(hhh]h)}(haAP SME capabilities, flags from :c:type:`enum nl80211_ap_sme_features `.h](h AP SME capabilities, flags from }(hjQ.hhhNhNubh)}(h@:c:type:`enum nl80211_ap_sme_features `h]j,)}(hj[.h]henum nl80211_ap_sme_features}(hj].hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjY.ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_ap_sme_featuresuh1hhjM.hMhjQ.ubh.}(hjQ.hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjM.hMhjN.ubah}(h]h ]h"]h$]h&]uh1jIhj2.ubeh}(h]h ]h"]h$]h&]uh1j)hjM.hMhj'*ubj*)}(hV``signal_type`` signal type reported in :c:type:`struct cfg80211_bss `. h](j0)}(h``signal_type``h]j,)}(hj.h]h signal_type}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj.ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj.ubjJ)}(hhh]h)}(hEsignal type reported in :c:type:`struct cfg80211_bss `.h](hsignal type reported in }(hj.hhhNhNubh)}(h,:c:type:`struct cfg80211_bss `h]j,)}(hj.h]hstruct cfg80211_bss}(hj.hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj.ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJ cfg80211_bssuh1hhj.hMhj.ubh.}(hj.hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj.hMhj.ubah}(h]h ]h"]h$]h&]uh1jIhj.ubeh}(h]h ]h"]h$]h&]uh1j)hj.hMhj'*ubj*)}(hh``bss_priv_size`` each BSS struct has private data allocated with it, this variable determines its size h](j0)}(h``bss_priv_size``h]j,)}(hj.h]h bss_priv_size}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj.ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj.ubjJ)}(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&]uh1jIhj.ubeh}(h]h ]h"]h$]h&]uh1j)hj/hMhj'*ubj*)}(hU``max_scan_ssids`` maximum number of SSIDs the device can scan for in any given scan h](j0)}(h``max_scan_ssids``h]j,)}(hj*/h]hmax_scan_ssids}(hj,/hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj(/ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj$/ubjJ)}(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}(hjC/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&]uh1jIhj$/ubeh}(h]h ]h"]h$]h&]uh1j)hj?/hMhj'*ubj*)}(hh``max_sched_scan_reqs`` maximum number of scheduled scan requests that the device can run concurrently. h](j0)}(h``max_sched_scan_reqs``h]j,)}(hjd/h]hmax_sched_scan_reqs}(hjf/hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjb/ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj^/ubjJ)}(hhh]h)}(hOmaximum number of scheduled scan requests that the device can run concurrently.h]hOmaximum number of scheduled scan requests that the device can run concurrently.}(hj}/hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjz/ubah}(h]h ]h"]h$]h&]uh1jIhj^/ubeh}(h]h ]h"]h$]h&]uh1j)hjy/hMhj'*ubj*)}(he``max_sched_scan_ssids`` maximum number of SSIDs the device can scan for in any given scheduled scan h](j0)}(h``max_sched_scan_ssids``h]j,)}(hj/h]hmax_sched_scan_ssids}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj/ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj/ubjJ)}(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}(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&]uh1jIhj/ubeh}(h]h ]h"]h$]h&]uh1j)hj/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](j0)}(h``max_match_sets``h]j,)}(hj/h]hmax_match_sets}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj/ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj/ubjJ)}(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&]uh1jIhj/ubeh}(h]h ]h"]h$]h&]uh1j)hj/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](j0)}(h``max_scan_ie_len``h]j,)}(hj0h]hmax_scan_ie_len}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj0ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj 0ubjJ)}(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+0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj(0ubah}(h]h ]h"]h$]h&]uh1jIhj 0ubeh}(h]h ]h"]h$]h&]uh1j)hj'0hMhj'*ubj*)}(hK``max_sched_scan_ie_len`` same as max_scan_ie_len, but for scheduled scans h](j0)}(h``max_sched_scan_ie_len``h]j,)}(hjL0h]hmax_sched_scan_ie_len}(hjN0hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjJ0ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjF0ubjJ)}(hhh]h)}(h0same as max_scan_ie_len, but for scheduled scansh]h0same as max_scan_ie_len, but for scheduled scans}(hje0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjb0ubah}(h]h ]h"]h$]h&]uh1jIhjF0ubeh}(h]h ]h"]h$]h&]uh1j)hja0hMhj'*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](j0)}(h``max_sched_scan_plans``h]j,)}(hj0h]hmax_sched_scan_plans}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj0ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj0ubjJ)}(hhh]h)}(hqmaximum number of scan plans (scan interval and number of iterations) for scheduled scan supported by the device.h]hqmaximum number of scan plans (scan interval and number of iterations) for scheduled scan supported by the device.}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj0ubah}(h]h ]h"]h$]h&]uh1jIhj0ubeh}(h]h ]h"]h$]h&]uh1j)hj0hMhj'*ubj*)}(ho``max_sched_scan_plan_interval`` maximum interval (in seconds) for a single scan plan supported by the device. h](j0)}(h ``max_sched_scan_plan_interval``h]j,)}(hj0h]hmax_sched_scan_plan_interval}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj0ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj0ubjJ)}(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&]uh1jIhj0ubeh}(h]h ]h"]h$]h&]uh1j)hj0hMhj'*ubj*)}(hp``max_sched_scan_plan_iterations`` maximum number of iterations for a single scan plan supported by the device. h](j0)}(h"``max_sched_scan_plan_iterations``h]j,)}(hj0h]hmax_sched_scan_plan_iterations}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj0ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj0ubjJ)}(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.}(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&]uh1jIhj0ubeh}(h]h ]h"]h$]h&]uh1j)hj1hMhj'*ubj*)}(h6``n_cipher_suites`` number of supported cipher suites h](j0)}(h``n_cipher_suites``h]j,)}(hj41h]hn_cipher_suites}(hj61hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj21ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj.1ubjJ)}(hhh]h)}(h!number of supported cipher suitesh]h!number of supported cipher suites}(hjM1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjI1hMhjJ1ubah}(h]h ]h"]h$]h&]uh1jIhj.1ubeh}(h]h ]h"]h$]h&]uh1j)hjI1hMhj'*ubj*)}(h*``cipher_suites`` supported cipher suites h](j0)}(h``cipher_suites``h]j,)}(hjm1h]h cipher_suites}(hjo1hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjk1ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjg1ubjJ)}(hhh]h)}(hsupported cipher suitesh]hsupported cipher suites}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1hMhj1ubah}(h]h ]h"]h$]h&]uh1jIhjg1ubeh}(h]h ]h"]h$]h&]uh1j)hj1hMhj'*ubj*)}(h0``n_akm_suites`` number of supported AKM suites h](j0)}(h``n_akm_suites``h]j,)}(hj1h]h n_akm_suites}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj1ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj1ubjJ)}(hhh]h)}(hnumber of supported AKM suitesh]hnumber of supported AKM suites}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1hMhj1ubah}(h]h ]h"]h$]h&]uh1jIhj1ubeh}(h]h ]h"]h$]h&]uh1j)hj1hMhj'*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](j0)}(h``akm_suites``h]j,)}(hj1h]h akm_suites}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj1ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj1ubjJ)}(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&]uh1jIhj1ubeh}(h]h ]h"]h$]h&]uh1j)hj1hMhj'*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](j0)}(h``iftype_akm_suites``h]j,)}(hj2h]hiftype_akm_suites}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj2ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubjJ)}(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 }(hj22hhhNhNubj)}(h**iftypes_mask**h]h iftypes_mask}(hj:2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj22ubh inside this structure cannot overlap (i.e. only one occurrence of each type is allowed across all instances of iftype_akm_suites).}(hj22hhhNhNubeh}(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&]uh1jIhj2ubeh}(h]h ]h"]h$]h&]uh1j)hj.2hMhj'*ubj*)}(hm``num_iftype_akm_suites`` number of interface types for which supported akm suites are specified separately. h](j0)}(h``num_iftype_akm_suites``h]j,)}(hje2h]hnum_iftype_akm_suites}(hjg2hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjc2ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj_2ubjJ)}(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.}(hj~2hhhNhNubah}(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&]uh1jIhj_2ubeh}(h]h ]h"]h$]h&]uh1j)hjz2hMhj'*ubj*)}(hD``retry_short`` Retry limit for short frames (dot11ShortRetryLimit) h](j0)}(h``retry_short``h]j,)}(hj2h]h retry_short}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj2ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubjJ)}(hhh]h)}(h3Retry limit for short frames (dot11ShortRetryLimit)h]h3Retry limit for short frames (dot11ShortRetryLimit)}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hMhj2ubah}(h]h ]h"]h$]h&]uh1jIhj2ubeh}(h]h ]h"]h$]h&]uh1j)hj2hMhj'*ubj*)}(hA``retry_long`` Retry limit for long frames (dot11LongRetryLimit) h](j0)}(h``retry_long``h]j,)}(hj2h]h retry_long}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj2ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj2ubjJ)}(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&]uh1jIhj2ubeh}(h]h ]h"]h$]h&]uh1j)hj2hMhj'*ubj*)}(h``frag_threshold`` Fragmentation threshold (dot11FragmentationThreshold); -1 = fragmentation disabled, only odd values >= 256 used h](j0)}(h``frag_threshold``h]j,)}(hj3h]hfrag_threshold}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj3ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj 3ubjJ)}(hhh]h)}(hoFragmentation threshold (dot11FragmentationThreshold); -1 = fragmentation disabled, only odd values >= 256 usedh]hoFragmentation threshold (dot11FragmentationThreshold); -1 = fragmentation disabled, only odd values >= 256 used}(hj*3hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj'3ubah}(h]h ]h"]h$]h&]uh1jIhj 3ubeh}(h]h ]h"]h$]h&]uh1j)hj&3hMhj'*ubj*)}(hK``rts_threshold`` RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabled h](j0)}(h``rts_threshold``h]j,)}(hjK3h]h rts_threshold}(hjM3hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjI3ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjE3ubjJ)}(hhh]h)}(h8RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabledh]h8RTS threshold (dot11RTSThreshold); -1 = RTS/CTS disabled}(hjd3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`3hMhja3ubah}(h]h ]h"]h$]h&]uh1jIhjE3ubeh}(h]h ]h"]h$]h&]uh1j)hj`3hMhj'*ubj*)}(h*``coverage_class`` current coverage class h](j0)}(h``coverage_class``h]j,)}(hj3h]hcoverage_class}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj3ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj~3ubjJ)}(hhh]h)}(hcurrent coverage classh]hcurrent coverage class}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMhj3ubah}(h]h ]h"]h$]h&]uh1jIhj~3ubeh}(h]h ]h"]h$]h&]uh1j)hj3hMhj'*ubj*)}(h6``fw_version`` firmware version for ethtool reporting h](j0)}(h``fw_version``h]j,)}(hj3h]h fw_version}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj3ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj3ubjJ)}(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&]uh1jIhj3ubeh}(h]h ]h"]h$]h&]uh1j)hj3hMhj'*ubj*)}(h6``hw_version`` hardware version for ethtool reporting h](j0)}(h``hw_version``h]j,)}(hj3h]h hw_version}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj3ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj3ubjJ)}(hhh]h)}(h&hardware version for ethtool reportingh]h&hardware version for ethtool reporting}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj 4hMhj 4ubah}(h]h ]h"]h$]h&]uh1jIhj3ubeh}(h]h ]h"]h$]h&]uh1j)hj 4hMhj'*ubj*)}(h&``wowlan`` WoWLAN support information h](j0)}(h ``wowlan``h]j,)}(hj/4h]hwowlan}(hj14hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj-4ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj)4ubjJ)}(hhh]h)}(hWoWLAN support informationh]hWoWLAN support information}(hjH4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjD4hMhjE4ubah}(h]h ]h"]h$]h&]uh1jIhj)4ubeh}(h]h ]h"]h$]h&]uh1j)hjD4hMhj'*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](j0)}(h``wowlan_config``h]j,)}(hjh4h]h wowlan_config}(hjj4hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjf4ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjb4ubjJ)}(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.}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj~4ubah}(h]h ]h"]h$]h&]uh1jIhjb4ubeh}(h]h ]h"]h$]h&]uh1j)hj}4hMhj'*ubj*)}(hk``max_remain_on_channel_duration`` Maximum time a remain-on-channel operation may request, if implemented. h](j0)}(h"``max_remain_on_channel_duration``h]j,)}(hj4h]hmax_remain_on_channel_duration}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj4ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj4ubjJ)}(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.}(hj4hhhNhNubah}(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&]uh1jIhj4ubeh}(h]h ]h"]h$]h&]uh1j)hj4hMhj'*ubj*)}(h@``max_num_pmkids`` maximum number of PMKIDs supported by device h](j0)}(h``max_num_pmkids``h]j,)}(hj4h]hmax_num_pmkids}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj4ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj4ubjJ)}(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&]uh1jIhj4ubeh}(h]h ]h"]h$]h&]uh1j)hj4hMhj'*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](j0)}(h``available_antennas_tx``h]j,)}(hj5h]havailable_antennas_tx}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj5ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj5ubjJ)}(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 }(hj.5hhhNhNubj)}(h**available_antennas_rx**h]havailable_antennas_rx}(hj65hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.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&]uh1jIhj5ubeh}(h]h ]h"]h$]h&]uh1j)hj*5hMhj'*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](j0)}(h``available_antennas_rx``h]j,)}(hja5h]havailable_antennas_rx}(hjc5hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj_5ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj[5ubjJ)}(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 }(hjz5hhhNhNubj)}(h**available_antennas_tx**h]havailable_antennas_tx}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjz5ubh is set.}(hjz5hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjw5ubah}(h]h ]h"]h$]h&]uh1jIhj[5ubeh}(h]h ]h"]h$]h&]uh1j)hjv5hM hj'*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](j0)}(h``probe_resp_offload``h]j,)}(hj5h]hprobe_resp_offload}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj5ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj5ubjJ)}(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 }(hj5hhhNhNubh)}(h`:c:type:`enum nl80211_probe_resp_offload_support_attr `h]j,)}(hj5h]h,enum nl80211_probe_resp_offload_support_attr}(hj5hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj5ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJ'nl80211_probe_resp_offload_support_attruh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj5ubh!. Only valid when the wiphy flag }(hj5hhhNhNubj)}(h$**WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD**h]h WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubh is set.}(hj5hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj5hMhj5ubah}(h]h ]h"]h$]h&]uh1jIhj5ubeh}(h]h ]h"]h$]h&]uh1j)hj5hMhj'*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](j0)}(h``extended_capabilities``h]j,)}(hj6h]hextended_capabilities}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM-hj6ubjJ)}(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.}(hj56hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM'hj26ubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j)hj16hM-hj'*ubj*)}(h8``extended_capabilities_mask`` mask of the valid values h](j0)}(h``extended_capabilities_mask``h]j,)}(hjV6h]hextended_capabilities_mask}(hjX6hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjT6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM.hjP6ubjJ)}(hhh]h)}(hmask of the valid valuesh]hmask of the valid values}(hjo6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjk6hM.hjl6ubah}(h]h ]h"]h$]h&]uh1jIhjP6ubeh}(h]h ]h"]h$]h&]uh1j)hjk6hM.hj'*ubj*)}(hB``extended_capabilities_len`` length of the extended capabilities h](j0)}(h``extended_capabilities_len``h]j,)}(hj6h]hextended_capabilities_len}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM/hj6ubjJ)}(hhh]h)}(h#length of the extended capabilitiesh]h#length of the extended capabilities}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM/hj6ubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j)hj6hM/hj'*ubj*)}(hG``iftype_ext_capab`` array of extended capabilities per interface type h](j0)}(h``iftype_ext_capab``h]j,)}(hj6h]hiftype_ext_capab}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM0hj6ubjJ)}(hhh]h)}(h1array of extended capabilities per interface typeh]h1array of extended capabilities per interface type}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM0hj6ubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j)hj6hM0hj'*ubj*)}(hm``num_iftype_ext_capab`` number of interface types for which extended capabilities are specified separately. h](j0)}(h``num_iftype_ext_capab``h]j,)}(hj7h]hnum_iftype_ext_capab}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM2hj6ubjJ)}(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.}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM1hj7ubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j)hj7hM2hj'*ubj*)}(hp``privid`` a pointer that drivers can use to identify if an arbitrary wiphy is theirs, e.g. in global notifiers h](j0)}(h ``privid``h]j,)}(hj;7h]hprivid}(hj=7hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj97ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj57ubjJ)}(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}(hjT7hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjQ7ubah}(h]h ]h"]h$]h&]uh1jIhj57ubeh}(h]h ]h"]h$]h&]uh1j)hjP7hMhj'*ubj*)}(hD``bands`` information about bands/channels supported by this device h](j0)}(h ``bands``h]j,)}(hju7h]hbands}(hjw7hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjs7ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjo7ubjJ)}(hhh]h)}(h9information about bands/channels supported by this deviceh]h9information about bands/channels supported by this device}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hMhj7ubah}(h]h ]h"]h$]h&]uh1jIhjo7ubeh}(h]h ]h"]h$]h&]uh1j)hj7hMhj'*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](j0)}(h``reg_notifier``h]j,)}(hj7h]h reg_notifier}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj7ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj7ubjJ)}(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}(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&]uh1jIhj7ubeh}(h]h ]h"]h$]h&]uh1j)hj7hMhj'*ubj*)}(h``radio_cfg`` configuration of radios belonging to a muli-radio wiphy. This struct contains a list of all radio specific attributes and should be used only for multi-radio wiphy. h](j0)}(h ``radio_cfg``h]j,)}(hj7h]h radio_cfg}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj7ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj7ubjJ)}(hhh]h)}(hconfiguration of radios belonging to a muli-radio wiphy. This struct contains a list of all radio specific attributes and should be used only for multi-radio wiphy.h]hconfiguration of radios belonging to a muli-radio wiphy. This struct contains a list of all radio specific attributes and should be used only for multi-radio wiphy.}(hj8hhhNhNubah}(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&]uh1jIhj7ubeh}(h]h ]h"]h$]h&]uh1j)hj7hMhj'*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](j0)}(h``regd``h]j,)}(hj"8h]hregd}(hj$8hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj 8ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj8ubjJ)}(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.}(hj;8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj88ubah}(h]h ]h"]h$]h&]uh1jIhj8ubeh}(h]h ]h"]h$]h&]uh1j)hj78hMhj'*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](j0)}(h``dev``h]j,)}(hj\8h]hdev}(hj^8hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjZ8ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjV8ubjJ)}(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).}(hju8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjr8ubah}(h]h ]h"]h$]h&]uh1jIhjV8ubeh}(h]h ]h"]h$]h&]uh1j)hjq8hMhj'*ubj*)}(h[``registered`` protects ->resume and ->suspend sysfs callbacks against unregister hardware h](j0)}(h``registered``h]j,)}(hj8h]h registered}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj8ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj8ubjJ)}(hhh]h)}(hKprotects ->resume and ->suspend sysfs callbacks against unregister hardwareh]hKprotects ->resume and ->suspend sysfs callbacks against unregister hardware}(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&]uh1jIhj8ubeh}(h]h ]h"]h$]h&]uh1j)hj8hMhj'*ubj*)}(h``debugfsdir`` debugfs directory used for this wiphy (ieee80211/). It will be renamed automatically on wiphy renames h](j0)}(h``debugfsdir``h]j,)}(hj8h]h debugfsdir}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj8ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj8ubjJ)}(hhh]h)}(hpdebugfs directory used for this wiphy (ieee80211/). It will be renamed automatically on wiphy renamesh]hpdebugfs directory used for this wiphy (ieee80211/). It will be renamed automatically on wiphy renames}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj8ubah}(h]h ]h"]h$]h&]uh1jIhj8ubeh}(h]h ]h"]h$]h&]uh1j)hj8hMhj'*ubj*)}(hk``ht_capa_mod_mask`` Specify what ht_cap values can be over-ridden. If null, then none can be over-ridden. h](j0)}(h``ht_capa_mod_mask``h]j,)}(hj 9h]hht_capa_mod_mask}(hj 9hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj9ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj9ubjJ)}(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.}(hj#9hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj 9ubah}(h]h ]h"]h$]h&]uh1jIhj9ubeh}(h]h ]h"]h$]h&]uh1j)hj9hMhj'*ubj*)}(ho``vht_capa_mod_mask`` Specify what VHT capabilities can be over-ridden. If null, then none can be over-ridden. h](j0)}(h``vht_capa_mod_mask``h]j,)}(hjD9h]hvht_capa_mod_mask}(hjF9hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjB9ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj>9ubjJ)}(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.}(hj]9hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjZ9ubah}(h]h ]h"]h$]h&]uh1jIhj>9ubeh}(h]h ]h"]h$]h&]uh1j)hjY9hMhj'*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](j0)}(h ``wdev_list``h]j,)}(hj~9h]h wdev_list}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj|9ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM"hjx9ubjJ)}(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.hhM!hj9ubah}(h]h ]h"]h$]h&]uh1jIhjx9ubeh}(h]h ]h"]h$]h&]uh1j)hj9hM"hj'*ubj*)}(h=``_net`` the network namespace this wiphy currently lives in h](j0)}(h``_net``h]j,)}(hj9h]h_net}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj9ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj9ubjJ)}(hhh]h)}(h3the network namespace this wiphy currently lives inh]h3the network namespace this wiphy currently lives in}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hMhj9ubah}(h]h ]h"]h$]h&]uh1jIhj9ubeh}(h]h ]h"]h$]h&]uh1j)hj9hMhj'*ubj*)}(h%``wext`` wireless extension handlers h](j0)}(h``wext``h]j,)}(hj9h]hwext}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj9ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj9ubjJ)}(hhh]h)}(hwireless extension handlersh]hwireless extension handlers}(hj :hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hMhj:ubah}(h]h ]h"]h$]h&]uh1jIhj9ubeh}(h]h ]h"]h$]h&]uh1j)hj:hMhj'*ubj*)}(h3``coalesce`` packet coalescing support information h](j0)}(h ``coalesce``h]j,)}(hj*:h]hcoalesce}(hj,:hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj(:ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM3hj$:ubjJ)}(hhh]h)}(h%packet coalescing support informationh]h%packet coalescing support information}(hjC:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?:hM3hj@:ubah}(h]h ]h"]h$]h&]uh1jIhj$:ubeh}(h]h ]h"]h$]h&]uh1j)hj?:hM3hj'*ubj*)}(hG``vendor_commands`` array of vendor commands supported by the hardware h](j0)}(h``vendor_commands``h]j,)}(hjc:h]hvendor_commands}(hje:hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hja:ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM5hj]:ubjJ)}(hhh]h)}(h2array of vendor commands supported by the hardwareh]h2array of vendor commands supported by the hardware}(hj|:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjx:hM5hjy:ubah}(h]h ]h"]h$]h&]uh1jIhj]:ubeh}(h]h ]h"]h$]h&]uh1j)hjx:hM5hj'*ubj*)}(hC``vendor_events`` array of vendor events supported by the hardware h](j0)}(h``vendor_events``h]j,)}(hj:h]h vendor_events}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj:ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM7hj:ubjJ)}(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:hM7hj:ubah}(h]h ]h"]h$]h&]uh1jIhj:ubeh}(h]h ]h"]h$]h&]uh1j)hj:hM7hj'*ubj*)}(h0``n_vendor_commands`` number of vendor commands h](j0)}(h``n_vendor_commands``h]j,)}(hj:h]hn_vendor_commands}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj:ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hj:ubjJ)}(hhh]h)}(hnumber of vendor commandsh]hnumber of vendor commands}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hM6hj:ubah}(h]h ]h"]h$]h&]uh1jIhj:ubeh}(h]h ]h"]h$]h&]uh1j)hj:hM6hj'*ubj*)}(h,``n_vendor_events`` number of vendor events h](j0)}(h``n_vendor_events``h]j,)}(hj;h]hn_vendor_events}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ;ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM8hj;ubjJ)}(hhh]h)}(hnumber of vendor eventsh]hnumber of vendor events}(hj';hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#;hM8hj$;ubah}(h]h ]h"]h$]h&]uh1jIhj;ubeh}(h]h ]h"]h$]h&]uh1j)hj#;hM8hj'*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](j0)}(h``max_ap_assoc_sta``h]j,)}(hjG;h]hmax_ap_assoc_sta}(hjI;hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjE;ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM=hjA;ubjJ)}(hhh]h)}(hmaximum number of associated stations supported in AP mode (including P2P GO) or 0 to indicate no such limit is advertised. The driver is allowed to advertise a theoretical limit that it can reach in some cases, but may not always reach.h]hmaximum number of associated stations supported in AP mode (including P2P GO) or 0 to indicate no such limit is advertised. The driver is allowed to advertise a theoretical limit that it can reach in some cases, but may not always reach.}(hj`;hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM:hj];ubah}(h]h ]h"]h$]h&]uh1jIhjA;ubeh}(h]h ]h"]h$]h&]uh1j)hj\;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](j0)}(h``max_num_csa_counters``h]j,)}(hj;h]hmax_num_csa_counters}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj;ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMBhj{;ubjJ)}(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&]uh1jIhj{;ubeh}(h]h ]h"]h$]h&]uh1j)hj;hMBhj'*ubj*)}(hX``bss_param_support`` bitmask indicating which bss_parameters as defined in :c:type:`struct bss_parameters ` the driver can actually handle in the .change_bss() callback. The bit positions are defined in :c:type:`enum wiphy_bss_param_flags `. h](j0)}(h``bss_param_support``h]j,)}(hj;h]hbss_param_support}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj;ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMFhj;ubjJ)}(hhh]h)}(hXbitmask indicating which bss_parameters as defined in :c:type:`struct bss_parameters ` the driver can actually handle in the .change_bss() callback. The bit positions are defined in :c:type:`enum wiphy_bss_param_flags `.h](h6bitmask indicating which bss_parameters as defined in }(hj;hhhNhNubh)}(h0:c:type:`struct bss_parameters `h]j,)}(hj;h]hstruct bss_parameters}(hj;hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj;ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJbss_parametersuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMChj;ubh` the driver can actually handle in the .change_bss() callback. The bit positions are defined in }(hj;hhhNhNubh)}(h<:c:type:`enum wiphy_bss_param_flags `h]j,)}(hj<h]henum wiphy_bss_param_flags}(hj<hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj<ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJwiphy_bss_param_flagsuh1hhj;hMChj;ubh.}(hj;hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj;hMChj;ubah}(h]h ]h"]h$]h&]uh1jIhj;ubeh}(h]h ]h"]h$]h&]uh1j)hj;hMFhj'*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](j0)}(h``bss_select_support``h]j,)}(hj;<h]hbss_select_support}(hj=<hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj9<ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMJhj5<ubjJ)}(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 }(hjT<hhhNhNubh)}(h@:c:type:`enum nl80211_bss_select_attr `h]j,)}(hj^<h]henum nl80211_bss_select_attr}(hj`<hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj\<ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_bss_select_attruh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMHhjT<ubh.}(hjT<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj{<hMHhjQ<ubah}(h]h ]h"]h$]h&]uh1jIhj5<ubeh}(h]h ]h"]h$]h&]uh1j)hjP<hMJhj'*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](j0)}(h``nan_supported_bands``h]j,)}(hj<h]hnan_supported_bands}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj<ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMOhj<ubjJ)}(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 ](j7j8c-typeeh"]h$]h&]uh1j+hj<ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJ nl80211_banduh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMLhj<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<hMLhj<ubah}(h]h ]h"]h$]h&]uh1jIhj<ubeh}(h]h ]h"]h$]h&]uh1j)hj<hMOhj'*ubj*)}(h``nan_capa`` NAN capabilities h](j0)}(h ``nan_capa``h]j,)}(hj<h]hnan_capa}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj<ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMPhj<ubjJ)}(hhh]h)}(hNAN capabilitiesh]hNAN capabilities}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj =hMPhj =ubah}(h]h ]h"]h$]h&]uh1jIhj<ubeh}(h]h ]h"]h$]h&]uh1j)hj =hMPhj'*ubj*)}(h=``txq_limit`` configuration of internal TX queue frame limit h](j0)}(h ``txq_limit``h]j,)}(hj.=h]h txq_limit}(hj0=hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj,=ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMRhj(=ubjJ)}(hhh]h)}(h.configuration of internal TX queue frame limith]h.configuration of internal TX queue frame limit}(hjG=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjC=hMRhjD=ubah}(h]h ]h"]h$]h&]uh1jIhj(=ubeh}(h]h ]h"]h$]h&]uh1j)hjC=hMRhj'*ubj*)}(hB``txq_memory_limit`` configuration internal TX queue memory limit h](j0)}(h``txq_memory_limit``h]j,)}(hjg=h]htxq_memory_limit}(hji=hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hje=ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMShja=ubjJ)}(hhh]h)}(h,configuration internal TX queue memory limith]h,configuration internal TX queue memory limit}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|=hMShj}=ubah}(h]h ]h"]h$]h&]uh1jIhja=ubeh}(h]h ]h"]h$]h&]uh1j)hj|=hMShj'*ubj*)}(hE``txq_quantum`` configuration of internal TX queue scheduler quantum h](j0)}(h``txq_quantum``h]j,)}(hj=h]h txq_quantum}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj=ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMThj=ubjJ)}(hhh]h)}(h4configuration of internal TX queue scheduler quantumh]h4configuration of internal TX queue scheduler quantum}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=hMThj=ubah}(h]h ]h"]h$]h&]uh1jIhj=ubeh}(h]h ]h"]h$]h&]uh1j)hj=hMThj'*ubj*)}(hV``tx_queue_len`` allow setting transmit queue len for drivers not using wake_tx_queue h](j0)}(h``tx_queue_len``h]j,)}(hj=h]h tx_queue_len}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj=ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMWhj=ubjJ)}(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.hhMVhj=ubah}(h]h ]h"]h$]h&]uh1jIhj=ubeh}(h]h ]h"]h$]h&]uh1j)hj=hMWhj'*ubj*)}(hE``support_mbssid`` can HW support association with nontransmitted AP h](j0)}(h``support_mbssid``h]j,)}(hj>h]hsupport_mbssid}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj>ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMYhj >ubjJ)}(hhh]h)}(h1can HW support association with nontransmitted APh]h1can HW support association with nontransmitted AP}(hj,>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(>hMYhj)>ubah}(h]h ]h"]h$]h&]uh1jIhj >ubeh}(h]h ]h"]h$]h&]uh1j)hj(>hMYhj'*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](j0)}(h``support_only_he_mbssid``h]j,)}(hjL>h]hsupport_only_he_mbssid}(hjN>hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjJ>ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM\hjF>ubjJ)}(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. }(hje>hhhNhNubj)}(h**support_mbssid**h]hsupport_mbssid}(hjm>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhje>ubh) must be set for this to have any effect.}(hje>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMZhjb>ubah}(h]h ]h"]h$]h&]uh1jIhjF>ubeh}(h]h ]h"]h$]h&]uh1j)hja>hM\hj'*ubj*)}(h,``pmsr_capa`` peer measurement capabilities h](j0)}(h ``pmsr_capa``h]j,)}(hj>h]h pmsr_capa}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj>ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM^hj>ubjJ)}(hhh]h)}(hpeer measurement capabilitiesh]hpeer measurement capabilities}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hM^hj>ubah}(h]h ]h"]h$]h&]uh1jIhj>ubeh}(h]h ]h"]h$]h&]uh1j)hj>hM^hj'*ubj*)}(hP``tid_config_support`` describes the per-TID config support that the device has h](j0)}(h``tid_config_support``h]j,)}(hj>h]htid_config_support}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj>ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMahj>ubjJ)}(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&]uh1jIhj>ubeh}(h]h ]h"]h$]h&]uh1j)hj>hMahj'*ubj*)}(hh``tid_config_support.peer`` bitmap of attributes (configurations) supported by the driver for each peer h](j0)}(h``tid_config_support.peer``h]j,)}(hj ?h]htid_config_support.peer}(hj ?hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ?ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMehj?ubjJ)}(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.hhMdhj!?ubah}(h]h ]h"]h$]h&]uh1jIhj?ubeh}(h]h ]h"]h$]h&]uh1j)hj ?hMehj'*ubj*)}(hf``tid_config_support.vif`` bitmap of attributes (configurations) supported by the driver for each vif h](j0)}(h``tid_config_support.vif``h]j,)}(hjE?h]htid_config_support.vif}(hjG?hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjC?ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMchj??ubjJ)}(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.hhMbhj[?ubah}(h]h ]h"]h$]h&]uh1jIhj??ubeh}(h]h ]h"]h$]h&]uh1j)hjZ?hMchj'*ubj*)}(hb``tid_config_support.max_retry`` maximum supported retry count for long/short retry configuration h](j0)}(h ``tid_config_support.max_retry``h]j,)}(hj?h]htid_config_support.max_retry}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj}?ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMghjy?ubjJ)}(hhh]h)}(h@maximum supported retry count for long/short retry configurationh]h@maximum supported retry count for long/short retry configuration}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMfhj?ubah}(h]h ]h"]h$]h&]uh1jIhjy?ubeh}(h]h ]h"]h$]h&]uh1j)hj?hMghj'*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](j0)}(h``max_data_retry_count``h]j,)}(hj?h]hmax_data_retry_count}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj?ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMkhj?ubjJ)}(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&]uh1j+hj?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&]uh1j+hj?ubh attributes}(hj?hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMihj?ubah}(h]h ]h"]h$]h&]uh1jIhj?ubeh}(h]h ]h"]h$]h&]uh1j)hj?hMkhj'*ubj*)}(h&``sar_capa`` SAR control capabilities h](j0)}(h ``sar_capa``h]j,)}(hj@h]hsar_capa}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj@ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMlhj@ubjJ)}(hhh]h)}(hSAR control capabilitiesh]hSAR control capabilities}(hj0@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,@hMlhj-@ubah}(h]h ]h"]h$]h&]uh1jIhj@ubeh}(h]h ]h"]h$]h&]uh1j)hj,@hMlhj'*ubj*)}(h-``rfkill`` a pointer to the rfkill structure h](j0)}(h ``rfkill``h]j,)}(hjP@h]hrfkill}(hjR@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjN@ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMmhjJ@ubjJ)}(hhh]h)}(h!a pointer to the rfkill structureh]h!a pointer to the rfkill structure}(hji@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhje@hMmhjf@ubah}(h]h ]h"]h$]h&]uh1jIhjJ@ubeh}(h]h ]h"]h$]h&]uh1j)hje@hMmhj'*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](j0)}(h``mbssid_max_interfaces``h]j,)}(hj@h]hmbssid_max_interfaces}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj@ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMqhj@ubjJ)}(hhh]h)}(hmaximum number of interfaces supported by the driver in a multiple BSSID set. This field must be set to a non-zero value by the driver to advertise MBSSID support.h]hmaximum number of interfaces supported by the driver in a multiple BSSID set. This field must be set to a non-zero value by the driver to advertise MBSSID support.}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMohj@ubah}(h]h ]h"]h$]h&]uh1jIhj@ubeh}(h]h ]h"]h$]h&]uh1j)hj@hMqhj'*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](j0)}(h``ema_max_profile_periodicity``h]j,)}(hj@h]hema_max_profile_periodicity}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj@ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMthj@ubjJ)}(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.hhMrhj@ubah}(h]h ]h"]h$]h&]uh1jIhj@ubeh}(h]h ]h"]h$]h&]uh1j)hj@hMthj'*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](j0)}(h``max_num_akm_suites``h]j,)}(hj@h]hmax_num_akm_suites}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj@ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM{hj@ubjJ)}(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 }(hjAhhhNhNubj,)}(h``NL80211_CMD_CONNECT``h]hNL80211_CMD_CONNECT}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjAubh, }(hjAhhhNhNubj,)}(h``NL80211_CMD_ASSOCIATE``h]hNL80211_CMD_ASSOCIATE}(hj0AhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjAubh and }(hjAhhhNhNubj,)}(h``NL80211_CMD_START_AP``h]hNL80211_CMD_START_AP}(hjBAhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjAubh. 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.}(hjAhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMuhjAubah}(h]h ]h"]h$]h&]uh1jIhj@ubeh}(h]h ]h"]h$]h&]uh1j)hjAhM{hj'*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](j0)}(h``hw_timestamp_max_peers``h]j,)}(hjmAh]hhw_timestamp_max_peers}(hjoAhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjkAubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjgAubjJ)}(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 }(hjAhhhNhNubj,)}(h#``CFG80211_HW_TIMESTAMP_ALL_PEERS``h]hCFG80211_HW_TIMESTAMP_ALL_PEERS}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjAubhn indicates the driver supports enabling HW timestamping for all peers (i.e. no need to specify a mac address).}(hjAhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM}hjAubah}(h]h ]h"]h$]h&]uh1jIhjgAubeh}(h]h ]h"]h$]h&]uh1j)hjAhMhj'*ubj*)}(h``n_radio`` number of radios h](j0)}(h ``n_radio``h]j,)}(hjAh]hn_radio}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjAubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjAubjJ)}(hhh]h)}(hnumber of radiosh]hnumber of radios}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhMhjAubah}(h]h ]h"]h$]h&]uh1jIhjAubeh}(h]h ]h"]h$]h&]uh1j)hjAhMhj'*ubj*)}(h)``radio`` radios belonging to this wiphy h](j0)}(h ``radio``h]j,)}(hjAh]hradio}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjAubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjAubjJ)}(hhh]h)}(hradios belonging to this wiphyh]hradios belonging to this wiphy}(hj BhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhMhjBubah}(h]h ]h"]h$]h&]uh1jIhjAubeh}(h]h ]h"]h$]h&]uh1j)hjBhMhj'*ubj*)}(hG``priv`` driver private data (sized according to wiphy_new() parameter)h](j0)}(h``priv``h]j,)}(hj+Bh]hpriv}(hj-BhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj)Bubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj%BubjJ)}(hhh]h)}(h>driver private data (sized according to wiphy_new() parameter)h]h>driver private data (sized according to wiphy_new() parameter)}(hjDBhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjABubah}(h]h ]h"]h$]h&]uh1jIhj%Bubeh}(h]h ]h"]h$]h&]uh1j)hj@BhMhj'*ubeh}(h]h ]h"]h$]h&]uh1j$hj)ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jswiphy_priv (C function) c.wiphy_privhNtauh1jfhhhhhNhNubjx)}(hhh](j})}(h'void * wiphy_priv (struct wiphy *wiphy)h]j)}(h%void *wiphy_priv(struct wiphy *wiphy)h](j)}(hvoidh]hvoid}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM4ubj)}(h h]h }(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBhhhjBhM4ubjz)}(hj}h]h*}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjBhhhjBhM4ubj)}(h wiphy_privh]j)}(h wiphy_privh]h wiphy_priv}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubah}(h]h ](jjeh"]h$]h&]jjuh1jhjBhhhjBhM4ubj)}(h(struct wiphy *wiphy)h]j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubj)}(h h]h }(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubh)}(hhh]j)}(hwiphyh]hwiphy}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjBmodnameN classnameNj j )}j ]jf)}j^jBsb c.wiphy_privasbuh1hhjBubj)}(h h]h }(hj ChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubjz)}(hj}h]h*}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjBubj)}(hwiphyh]hwiphy}(hj(ChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjBubah}(h]h ]h"]h$]h&]jjuh1jhjBhhhjBhM4ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj}BhhhjBhM4ubah}(h]jxBah ](jjeh"]h$]h&]jj)jhuh1j|hjBhM4hjzBhhubj)}(hhh]h)}(hreturn priv from wiphyh]hreturn priv from wiphy}(hjRChhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM4hjOChhubah}(h]h ]h"]h$]h&]uh1jhjzBhhhjBhM4ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjjCjjjCjjjuh1jwhhhhhNhNubj)}(ht**Parameters** ``struct wiphy *wiphy`` the wiphy whose priv pointer to return **Return** The priv of **wiphy**.h](h)}(h**Parameters**h]j)}(hjtCh]h Parameters}(hjvChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrCubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM8hjnCubj%)}(hhh]j*)}(h?``struct wiphy *wiphy`` the wiphy whose priv pointer to return h](j0)}(h``struct wiphy *wiphy``h]j,)}(hjCh]hstruct wiphy *wiphy}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjCubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hjCubjJ)}(hhh]h)}(h&the wiphy whose priv pointer to returnh]h&the wiphy whose priv pointer to return}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChM6hjCubah}(h]h ]h"]h$]h&]uh1jIhjCubeh}(h]h ]h"]h$]h&]uh1j)hjChM6hjCubah}(h]h ]h"]h$]h&]uh1j$hjnCubh)}(h **Return**h]j)}(hjCh]hReturn}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM8hjnCubh)}(hThe priv of **wiphy**.h](h The priv of }(hjChhhNhNubj)}(h **wiphy**h]hwiphy}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubh.}(hjChhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM7hjnCubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jspriv_to_wiphy (C function)c.priv_to_wiphyhNtauh1jfhhhhhNhNubjx)}(hhh](j})}(h)struct wiphy * priv_to_wiphy (void *priv)h]j)}(h'struct wiphy *priv_to_wiphy(void *priv)h](j)}(hjh]hstruct}(hj%DhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!Dhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM@ubj)}(h h]h }(hj3DhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!Dhhhj2DhM@ubh)}(hhh]j)}(hwiphyh]hwiphy}(hjDDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjADubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjFDmodnameN classnameNj j )}j ]jf)}j^ priv_to_wiphysbc.priv_to_wiphyasbuh1hhj!Dhhhj2DhM@ubj)}(h h]h }(hjeDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!Dhhhj2DhM@ubjz)}(hj}h]h*}(hjsDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj!Dhhhj2DhM@ubj)}(h priv_to_wiphyh]j)}(hjbDh]h priv_to_wiphy}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDubah}(h]h ](jjeh"]h$]h&]jjuh1jhj!Dhhhj2DhM@ubj)}(h (void *priv)h]j%)}(h void *privh](j)}(hvoidh]hvoid}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDubj)}(h h]h }(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDubjz)}(hj}h]h*}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjDubj)}(hprivh]hpriv}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjDubah}(h]h ]h"]h$]h&]jjuh1jhj!Dhhhj2DhM@ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjDhhhj2DhM@ubah}(h]jDah ](jjeh"]h$]h&]jj)jhuh1j|hj2DhM@hjDhhubj)}(hhh]h)}(h$return the wiphy containing the privh]h$return the wiphy containing the priv}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM@hjDhhubah}(h]h ]h"]h$]h&]uh1jhjDhhhj2DhM@ubeh}(h]h ](j8functioneh"]h$]h&]jj8jj Ejj Ejjjuh1jwhhhhhNhNubj)}(hp**Parameters** ``void *priv`` a pointer previously returned by wiphy_priv **Return** The wiphy of **priv**.h](h)}(h**Parameters**h]j)}(hjEh]h Parameters}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMDhjEubj%)}(hhh]j*)}(h;``void *priv`` a pointer previously returned by wiphy_priv h](j0)}(h``void *priv``h]j,)}(hj3Eh]h void *priv}(hj5EhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj1Eubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMBhj-EubjJ)}(hhh]h)}(h+a pointer previously returned by wiphy_privh]h+a pointer previously returned by wiphy_priv}(hjLEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHEhMBhjIEubah}(h]h ]h"]h$]h&]uh1jIhj-Eubeh}(h]h ]h"]h$]h&]uh1j)hjHEhMBhj*Eubah}(h]h ]h"]h$]h&]uh1j$hjEubh)}(h **Return**h]j)}(hjnEh]hReturn}(hjpEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlEubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMDhjEubh)}(hThe wiphy of **priv**.h](h The wiphy of }(hjEhhhNhNubj)}(h**priv**h]hpriv}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubh.}(hjEhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMChjEubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsset_wiphy_dev (C function)c.set_wiphy_devhNtauh1jfhhhhhNhNubjx)}(hhh](j})}(hIubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM[hjHubh)}(hThe dev of **wiphy**.h](h The dev of }(hjVIhhhNhNubj)}(h **wiphy**h]hwiphy}(hj^IhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVIubh.}(hjVIhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMZhjHubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jswiphy_name (C function) c.wiphy_namehNtauh1jfhhhhhNhNubjx)}(hhh](j})}(h3const char * wiphy_name (const struct wiphy *wiphy)h]j)}(h1const char *wiphy_name(const struct wiphy *wiphy)h](j)}(hconsth]hconst}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMbubj)}(h h]h }(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIhhhjIhMbubj)}(hcharh]hchar}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIhhhjIhMbubj)}(h h]h }(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIhhhjIhMbubjz)}(hj}h]h*}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjIhhhjIhMbubj)}(h wiphy_nameh]j)}(h wiphy_nameh]h wiphy_name}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubah}(h]h ](jjeh"]h$]h&]jjuh1jhjIhhhjIhMbubj)}(h(const struct wiphy *wiphy)h]j%)}(hconst struct wiphy *wiphyh](j)}(hjIh]hconst}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubj)}(h h]h }(hj JhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubj)}(hjh]hstruct}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubj)}(h h]h }(hj%JhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubh)}(hhh]j)}(hwiphyh]hwiphy}(hj6JhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3Jubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj8JmodnameN classnameNj j )}j ]jf)}j^jIsb c.wiphy_nameasbuh1hhjIubj)}(h h]h }(hjVJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubjz)}(hj}h]h*}(hjdJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjIubj)}(hwiphyh]hwiphy}(hjqJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjIubah}(h]h ]h"]h$]h&]jjuh1jhjIhhhjIhMbubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjIhhhjIhMbubah}(h]jIah ](jjeh"]h$]h&]jj)jhuh1j|hjIhMbhjIhhubj)}(hhh]h)}(hget wiphy nameh]hget wiphy name}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMbhjJhhubah}(h]h ]h"]h$]h&]uh1jhjIhhhjIhMbubeh}(h]h ](j8functioneh"]h$]h&]jj8jjJjjJjjjuh1jwhhhhhNhNubj)}(hr**Parameters** ``const struct wiphy *wiphy`` The wiphy whose name to return **Return** The name of **wiphy**.h](h)}(h**Parameters**h]j)}(hjJh]h Parameters}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMfhjJubj%)}(hhh]j*)}(h=``const struct wiphy *wiphy`` The wiphy whose name to return h](j0)}(h``const struct wiphy *wiphy``h]j,)}(hjJh]hconst struct wiphy *wiphy}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjJubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMdhjJubjJ)}(hhh]h)}(hThe wiphy whose name to returnh]hThe wiphy whose name to return}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhMdhjJubah}(h]h ]h"]h$]h&]uh1jIhjJubeh}(h]h ]h"]h$]h&]uh1j)hjJhMdhjJubah}(h]h ]h"]h$]h&]uh1j$hjJubh)}(h **Return**h]j)}(hjKh]hReturn}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMfhjJubh)}(hThe name of **wiphy**.h](h The name of }(hj-KhhhNhNubj)}(h **wiphy**h]hwiphy}(hj5KhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-Kubh.}(hj-KhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMehjJubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jswiphy_new (C function) c.wiphy_newhNtauh1jfhhhhhNhNubjx)}(hhh](j})}(hJstruct wiphy * wiphy_new (const struct cfg80211_ops *ops, int sizeof_priv)h]j)}(hHstruct wiphy *wiphy_new(const struct cfg80211_ops *ops, int sizeof_priv)h](j)}(hjh]hstruct}(hjnKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjKhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM~ubj)}(h h]h }(hj|KhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjKhhhj{KhM~ubh)}(hhh]j)}(hwiphyh]hwiphy}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjKmodnameN classnameNj j )}j ]jf)}j^ wiphy_newsb c.wiphy_newasbuh1hhjjKhhhj{KhM~ubj)}(h h]h }(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjKhhhj{KhM~ubjz)}(hj}h]h*}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjjKhhhj{KhM~ubj)}(h wiphy_newh]j)}(hjKh]h wiphy_new}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubah}(h]h ](jjeh"]h$]h&]jjuh1jhjjKhhhj{KhM~ubj)}(h1(const struct cfg80211_ops *ops, int sizeof_priv)h](j%)}(hconst struct cfg80211_ops *opsh](j)}(hjIh]hconst}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubj)}(h h]h }(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubj)}(hjh]hstruct}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubj)}(h h]h }(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubh)}(hhh]j)}(h cfg80211_opsh]h cfg80211_ops}(hj!LhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj#LmodnameN classnameNj j )}j ]jK c.wiphy_newasbuh1hhjKubj)}(h h]h }(hj?LhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubjz)}(hj}h]h*}(hjMLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjKubj)}(hopsh]hops}(hjZLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjKubj%)}(hint sizeof_privh](j)}(hinth]hint}(hjsLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoLubj)}(h h]h }(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoLubj)}(h sizeof_privh]h sizeof_priv}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoLubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjKubeh}(h]h ]h"]h$]h&]jjuh1jhjjKhhhj{KhM~ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjfKhhhj{KhM~ubah}(h]jaKah ](jjeh"]h$]h&]jj)jhuh1j|hj{KhM~hjcKhhubj)}(hhh]h)}(h(create a new wiphy for use with cfg80211h]h(create a new wiphy for use with cfg80211}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM~hjLhhubah}(h]h ]h"]h$]h&]uh1jhjcKhhhj{KhM~ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjLjjLjjjuh1jwhhhhhNhNubj)}(hX**Parameters** ``const struct cfg80211_ops *ops`` The configuration operations for this device ``int sizeof_priv`` The size of the private area to allocate **Description** Create a new wiphy and associate the given operations with it. **sizeof_priv** bytes are allocated for private use. **Return** A pointer to the new wiphy. This pointer must be assigned to each netdev's ieee80211_ptr for proper operation.h](h)}(h**Parameters**h]j)}(hjLh]h Parameters}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjLubj%)}(hhh](j*)}(hP``const struct cfg80211_ops *ops`` The configuration operations for this device h](j0)}(h"``const struct cfg80211_ops *ops``h]j,)}(hjLh]hconst struct cfg80211_ops *ops}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjLubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjLubjJ)}(hhh]h)}(h,The configuration operations for this deviceh]h,The configuration operations for this device}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMhMhjMubah}(h]h ]h"]h$]h&]uh1jIhjLubeh}(h]h ]h"]h$]h&]uh1j)hjMhMhjLubj*)}(h=``int sizeof_priv`` The size of the private area to allocate h](j0)}(h``int sizeof_priv``h]j,)}(hj3Mh]hint sizeof_priv}(hj5MhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj1Mubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj-MubjJ)}(hhh]h)}(h(The size of the private area to allocateh]h(The size of the private area to allocate}(hjLMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHMhMhjIMubah}(h]h ]h"]h$]h&]uh1jIhj-Mubeh}(h]h ]h"]h$]h&]uh1j)hjHMhMhjLubeh}(h]h ]h"]h$]h&]uh1j$hjLubh)}(h**Description**h]j)}(hjnMh]h Description}(hjpMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlMubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjLubh)}(hsCreate a new wiphy and associate the given operations with it. **sizeof_priv** bytes are allocated for private use.h](h?Create a new wiphy and associate the given operations with it. }(hjMhhhNhNubj)}(h**sizeof_priv**h]h sizeof_priv}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubh% bytes are allocated for private use.}(hjMhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjLubh)}(h **Return**h]j)}(hjMh]hReturn}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjLubh)}(hnA pointer to the new wiphy. This pointer must be assigned to each netdev's ieee80211_ptr for proper operation.h]hpA pointer to the new wiphy. This pointer must be assigned to each netdev’s ieee80211_ptr for proper operation.}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjLubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jswiphy_register (C function)c.wiphy_registerhNtauh1jfhhhhhNhNubjx)}(hhh](j})}(h(int wiphy_register (struct wiphy *wiphy)h]j)}(h'int wiphy_register(struct wiphy *wiphy)h](j)}(hinth]hint}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMhhhjMhMubj)}(hwiphy_registerh]j)}(hwiphy_registerh]hwiphy_register}(hj NhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj Nubah}(h]h ](jjeh"]h$]h&]jjuh1jhjMhhhjMhMubj)}(h(struct wiphy *wiphy)h]j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hj)NhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%Nubj)}(h h]h }(hj6NhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%Nubh)}(hhh]j)}(hwiphyh]hwiphy}(hjGNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDNubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjINmodnameN classnameNj j )}j ]jf)}j^jNsbc.wiphy_registerasbuh1hhj%Nubj)}(h h]h }(hjgNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%Nubjz)}(hj}h]h*}(hjuNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj%Nubj)}(hwiphyh]hwiphy}(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%Nubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj!Nubah}(h]h ]h"]h$]h&]jjuh1jhjMhhhjMhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjMhhhjMhMubah}(h]jMah ](jjeh"]h$]h&]jj)jhuh1j|hjMhMhjMhhubj)}(hhh]h)}(hregister a wiphy with cfg80211h]hregister a wiphy with cfg80211}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjNhhubah}(h]h ]h"]h$]h&]uh1jhjMhhhjMhMubeh}(h]h ](j8functioneh"]h$]h&]jj8jjNjjNjjjuh1jwhhhhhNhNubj)}(h**Parameters** ``struct wiphy *wiphy`` The wiphy to register. **Return** A non-negative wiphy index or a negative error code.h](h)}(h**Parameters**h]j)}(hjNh]h Parameters}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjNubj%)}(hhh]j*)}(h/``struct wiphy *wiphy`` The wiphy to register. h](j0)}(h``struct wiphy *wiphy``h]j,)}(hjNh]hstruct wiphy *wiphy}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjNubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjNubjJ)}(hhh]h)}(hThe wiphy to register.h]hThe wiphy to register.}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOhMhjOubah}(h]h ]h"]h$]h&]uh1jIhjNubeh}(h]h ]h"]h$]h&]uh1j)hjOhMhjNubah}(h]h ]h"]h$]h&]uh1j$hjNubh)}(h **Return**h]j)}(hj(Oh]hReturn}(hj*OhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&Oubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjNubh)}(h4A non-negative wiphy index or a negative error code.h]h4A non-negative wiphy index or a negative error code.}(hj>OhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjNubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jswiphy_unregister (C function)c.wiphy_unregisterhNtauh1jfhhhhhNhNubjx)}(hhh](j})}(h+void wiphy_unregister (struct wiphy *wiphy)h]j)}(h*void wiphy_unregister(struct wiphy *wiphy)h](j)}(hvoidh]hvoid}(hjmOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjiOhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hj|OhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjiOhhhj{OhMubj)}(hwiphy_unregisterh]j)}(hwiphy_unregisterh]hwiphy_unregister}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubah}(h]h ](jjeh"]h$]h&]jjuh1jhjiOhhhj{OhMubj)}(h(struct wiphy *wiphy)h]j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubj)}(h h]h }(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubh)}(hhh]j)}(hwiphyh]hwiphy}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjOmodnameN classnameNj j )}j ]jf)}j^jOsbc.wiphy_unregisterasbuh1hhjOubj)}(h h]h }(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubjz)}(hj}h]h*}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjOubj)}(hwiphyh]hwiphy}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjOubah}(h]h ]h"]h$]h&]jjuh1jhjiOhhhj{OhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjeOhhhj{OhMubah}(h]j`Oah ](jjeh"]h$]h&]jj)jhuh1j|hj{OhMhjbOhhubj)}(hhh]h)}(h deregister a wiphy from cfg80211h]h deregister a wiphy from cfg80211}(hj-PhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj*Phhubah}(h]h ]h"]h$]h&]uh1jhjbOhhhj{OhMubeh}(h]h ](j8functioneh"]h$]h&]jj8jjEPjjEPjjjuh1jwhhhhhNhNubj)}(h**Parameters** ``struct wiphy *wiphy`` The wiphy to unregister. **Description** After this call, no more requests can be made with this priv pointer, but the call may sleep to wait for an outstanding request that is being handled.h](h)}(h**Parameters**h]j)}(hjOPh]h Parameters}(hjQPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMPubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjIPubj%)}(hhh]j*)}(h1``struct wiphy *wiphy`` The wiphy to unregister. h](j0)}(h``struct wiphy *wiphy``h]j,)}(hjnPh]hstruct wiphy *wiphy}(hjpPhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjlPubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjhPubjJ)}(hhh]h)}(hThe wiphy to unregister.h]hThe wiphy to unregister.}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhMhjPubah}(h]h ]h"]h$]h&]uh1jIhjhPubeh}(h]h ]h"]h$]h&]uh1j)hjPhMhjePubah}(h]h ]h"]h$]h&]uh1j$hjIPubh)}(h**Description**h]j)}(hjPh]h Description}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjIPubh)}(hAfter this call, no more requests can be made with this priv pointer, but the call may sleep to wait for an outstanding request that is being handled.h]hAfter this call, no more requests can be made with this priv pointer, but the call may sleep to wait for an outstanding request that is being handled.}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjIPubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jswiphy_free (C function) c.wiphy_freehNtauh1jfhhhhhNhNubjx)}(hhh](j})}(h%void wiphy_free (struct wiphy *wiphy)h]j)}(h$void wiphy_free(struct wiphy *wiphy)h](j)}(hvoidh]hvoid}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPhhhjPhMubj)}(h wiphy_freeh]j)}(h wiphy_freeh]h wiphy_free}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj Qubah}(h]h ](jjeh"]h$]h&]jjuh1jhjPhhhjPhMubj)}(h(struct wiphy *wiphy)h]j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hj+QhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'Qubj)}(h h]h }(hj8QhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'Qubh)}(hhh]j)}(hwiphyh]hwiphy}(hjIQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjFQubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjKQmodnameN classnameNj j )}j ]jf)}j^jQsb c.wiphy_freeasbuh1hhj'Qubj)}(h h]h }(hjiQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'Qubjz)}(hj}h]h*}(hjwQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj'Qubj)}(hwiphyh]hwiphy}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'Qubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj#Qubah}(h]h ]h"]h$]h&]jjuh1jhjPhhhjPhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjPhhhjPhMubah}(h]jPah ](jjeh"]h$]h&]jj)jhuh1j|hjPhMhjPhhubj)}(hhh]h)}(h free wiphyh]h free wiphy}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjQhhubah}(h]h ]h"]h$]h&]uh1jhjPhhhjPhMubeh}(h]h ](j8functioneh"]h$]h&]jj8jjQjjQjjjuh1jwhhhhhNhNubj)}(h;**Parameters** ``struct wiphy *wiphy`` The wiphy to freeh](h)}(h**Parameters**h]j)}(hjQh]h Parameters}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjQubj%)}(hhh]j*)}(h)``struct wiphy *wiphy`` The wiphy to freeh](j0)}(h``struct wiphy *wiphy``h]j,)}(hjQh]hstruct wiphy *wiphy}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjQubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjQubjJ)}(hhh]h)}(hThe wiphy to freeh]hThe wiphy to free}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjRubah}(h]h ]h"]h$]h&]uh1jIhjQubeh}(h]h ]h"]h$]h&]uh1j)hjRhMhjQubah}(h]h ]h"]h$]h&]uh1j$hjQubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jswireless_dev (C struct)c.wireless_devhNtauh1jfhhhhhNhNubjx)}(hhh](j})}(h wireless_devh]j)}(hstruct wireless_devh](j)}(hjh]hstruct}(hjIRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjERhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hjWRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjERhhhjVRhMubj)}(h wireless_devh]j)}(hjCRh]h wireless_dev}(hjiRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeRubah}(h]h ](jjeh"]h$]h&]jjuh1jhjERhhhjVRhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjARhhhjVRhMubah}(h]jRhhubj)}(hhh]h)}(hwireless device stateh]hwireless device state}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjRhhubah}(h]h ]h"]h$]h&]uh1jhj>RhhhjVRhMubeh}(h]h ](j8structeh"]h$]h&]jj8jjRjjRjjjuh1jwhhhhhNhNubj)}(hXi**Definition**:: struct wireless_dev { struct wiphy *wiphy; enum nl80211_iftype iftype; struct list_head list; struct net_device *netdev; u32 identifier; struct list_head mgmt_registrations; u8 mgmt_registrations_need_update:1; bool use_4addr, is_running, registered, registering; u8 address[ETH_ALEN]; struct cfg80211_conn *conn; struct cfg80211_cached_keys *connect_keys; enum ieee80211_bss_type conn_bss_type; u32 conn_owner_nlportid; struct work_struct disconnect_wk; u8 disconnect_bssid[ETH_ALEN]; struct list_head event_list; spinlock_t event_lock; u8 connected:1; bool ps; int ps_timeout; u32 unexpected_nlportid; u32 owner_nlportid; bool nl_owner_dead; #ifdef CONFIG_CFG80211_WEXT; struct { struct cfg80211_ibss_params ibss; struct cfg80211_connect_params connect; struct cfg80211_cached_keys *keys; const u8 *ie; size_t ie_len; u8 bssid[ETH_ALEN]; u8 prev_bssid[ETH_ALEN]; u8 ssid[IEEE80211_MAX_SSID_LEN]; s8 default_key, default_mgmt_key; bool prev_bssid_valid; } wext; #endif; struct wiphy_work cqm_rssi_work; struct cfg80211_cqm_config *cqm_config; struct list_head pmsr_list; spinlock_t pmsr_lock; struct work_struct pmsr_free_wk; unsigned long unprot_beacon_reported; union { struct { u8 connected_addr[ETH_ALEN]; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } client; struct { int beacon_interval; struct cfg80211_chan_def preset_chandef; struct cfg80211_chan_def chandef; u8 id[IEEE80211_MAX_MESH_ID_LEN]; u8 id_len, id_up_len; } mesh; struct { struct cfg80211_chan_def preset_chandef; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } ap; struct { struct cfg80211_internal_bss *current_bss; struct cfg80211_chan_def chandef; int beacon_interval; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } ibss; struct { struct cfg80211_chan_def chandef; } ocb; struct { u8 cluster_id[ETH_ALEN]; u8 n_channels; struct cfg80211_chan_def *chandefs; bool sched_update_pending; } nan; } u; struct { u8 addr[ETH_ALEN]; union { struct { unsigned int beacon_interval; struct cfg80211_chan_def chandef; } ap; struct { struct cfg80211_internal_bss *current_bss; } client; }; bool cac_started; unsigned long cac_start_time; unsigned int cac_time_ms; } links[IEEE80211_MLD_MAX_NUM_LINKS]; u16 valid_links; u32 radio_mask; }; **Members** ``wiphy`` pointer to hardware description ``iftype`` interface type ``list`` (private) Used to collect the interfaces ``netdev`` (private) Used to reference back to the netdev, may be ``NULL`` ``identifier`` (private) Identifier used in nl80211 to identify this wireless device if it has no netdev ``mgmt_registrations`` list of registrations for management frames ``mgmt_registrations_need_update`` mgmt registrations were updated, need to propagate the update to the driver ``use_4addr`` indicates 4addr mode is used on this interface, must be set by driver (if supported) on add_interface BEFORE registering the netdev and may otherwise be used by driver read-only, will be update by cfg80211 on change_interface ``is_running`` true if this is a non-netdev device that has been started, e.g. the P2P Device. ``registered`` is this wdev already registered with cfg80211 ``registering`` indicates we're doing registration under wiphy lock for the notifier ``address`` The address for this device, valid only if **netdev** is ``NULL`` ``conn`` (private) cfg80211 software SME connection state machine data ``connect_keys`` (private) keys to set after connection is established ``conn_bss_type`` connecting/connected BSS type ``conn_owner_nlportid`` (private) connection owner socket port ID ``disconnect_wk`` (private) auto-disconnect work ``disconnect_bssid`` (private) the BSSID to use for auto-disconnect ``event_list`` (private) list for internal event processing ``event_lock`` (private) lock for event list ``connected`` indicates if connected or not (STA mode) ``ps`` powersave mode is enabled ``ps_timeout`` dynamic powersave timeout ``unexpected_nlportid`` (private) netlink port ID of application registered for unexpected frames (AP mode or NAN_DATA mode) ``owner_nlportid`` (private) owner socket port ID ``nl_owner_dead`` (private) owner socket went away ``wext`` (private) Used by the internal wireless extensions compat code ``wext.ibss`` (private) IBSS data part of wext handling ``wext.connect`` (private) connection handling data ``wext.keys`` (private) (WEP) key data ``wext.ie`` (private) extra elements for association ``wext.ie_len`` (private) length of extra elements ``wext.bssid`` (private) selected network BSSID ``wext.prev_bssid`` (private) previous BSSID for reassociation ``wext.ssid`` (private) selected network SSID ``wext.default_key`` (private) selected default key index ``wext.default_mgmt_key`` (private) selected default management key index ``wext.prev_bssid_valid`` (private) previous BSSID validity ``cqm_rssi_work`` (private) CQM RSSI reporting work ``cqm_config`` (private) nl80211 RSSI monitor state ``pmsr_list`` (private) peer measurement requests ``pmsr_lock`` (private) peer measurements requests/results lock ``pmsr_free_wk`` (private) peer measurements cleanup work ``unprot_beacon_reported`` (private) timestamp of last unprotected beacon report ``u`` union containing data specific to **iftype** ``links`` array of ``IEEE80211_MLD_MAX_NUM_LINKS`` elements containing **addr** **ap** and **client** for each link ``{unnamed_union}`` anonymous ``links.cac_started`` true if DFS channel availability check has been started ``links.cac_start_time`` timestamp (jiffies) when the dfs state was entered. ``links.cac_time_ms`` CAC time in ms ``valid_links`` bitmap describing what elements of **links** are valid ``radio_mask`` Bitmask of radios that this interface is allowed to operate on.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubh:}(hjRhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjRubj: )}(hXh struct wireless_dev { struct wiphy *wiphy; enum nl80211_iftype iftype; struct list_head list; struct net_device *netdev; u32 identifier; struct list_head mgmt_registrations; u8 mgmt_registrations_need_update:1; bool use_4addr, is_running, registered, registering; u8 address[ETH_ALEN]; struct cfg80211_conn *conn; struct cfg80211_cached_keys *connect_keys; enum ieee80211_bss_type conn_bss_type; u32 conn_owner_nlportid; struct work_struct disconnect_wk; u8 disconnect_bssid[ETH_ALEN]; struct list_head event_list; spinlock_t event_lock; u8 connected:1; bool ps; int ps_timeout; u32 unexpected_nlportid; u32 owner_nlportid; bool nl_owner_dead; #ifdef CONFIG_CFG80211_WEXT; struct { struct cfg80211_ibss_params ibss; struct cfg80211_connect_params connect; struct cfg80211_cached_keys *keys; const u8 *ie; size_t ie_len; u8 bssid[ETH_ALEN]; u8 prev_bssid[ETH_ALEN]; u8 ssid[IEEE80211_MAX_SSID_LEN]; s8 default_key, default_mgmt_key; bool prev_bssid_valid; } wext; #endif; struct wiphy_work cqm_rssi_work; struct cfg80211_cqm_config *cqm_config; struct list_head pmsr_list; spinlock_t pmsr_lock; struct work_struct pmsr_free_wk; unsigned long unprot_beacon_reported; union { struct { u8 connected_addr[ETH_ALEN]; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } client; struct { int beacon_interval; struct cfg80211_chan_def preset_chandef; struct cfg80211_chan_def chandef; u8 id[IEEE80211_MAX_MESH_ID_LEN]; u8 id_len, id_up_len; } mesh; struct { struct cfg80211_chan_def preset_chandef; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } ap; struct { struct cfg80211_internal_bss *current_bss; struct cfg80211_chan_def chandef; int beacon_interval; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } ibss; struct { struct cfg80211_chan_def chandef; } ocb; struct { u8 cluster_id[ETH_ALEN]; u8 n_channels; struct cfg80211_chan_def *chandefs; bool sched_update_pending; } nan; } u; struct { u8 addr[ETH_ALEN]; union { struct { unsigned int beacon_interval; struct cfg80211_chan_def chandef; } ap; struct { struct cfg80211_internal_bss *current_bss; } client; }; bool cac_started; unsigned long cac_start_time; unsigned int cac_time_ms; } links[IEEE80211_MLD_MAX_NUM_LINKS]; u16 valid_links; u32 radio_mask; };h]hXh struct wireless_dev { struct wiphy *wiphy; enum nl80211_iftype iftype; struct list_head list; struct net_device *netdev; u32 identifier; struct list_head mgmt_registrations; u8 mgmt_registrations_need_update:1; bool use_4addr, is_running, registered, registering; u8 address[ETH_ALEN]; struct cfg80211_conn *conn; struct cfg80211_cached_keys *connect_keys; enum ieee80211_bss_type conn_bss_type; u32 conn_owner_nlportid; struct work_struct disconnect_wk; u8 disconnect_bssid[ETH_ALEN]; struct list_head event_list; spinlock_t event_lock; u8 connected:1; bool ps; int ps_timeout; u32 unexpected_nlportid; u32 owner_nlportid; bool nl_owner_dead; #ifdef CONFIG_CFG80211_WEXT; struct { struct cfg80211_ibss_params ibss; struct cfg80211_connect_params connect; struct cfg80211_cached_keys *keys; const u8 *ie; size_t ie_len; u8 bssid[ETH_ALEN]; u8 prev_bssid[ETH_ALEN]; u8 ssid[IEEE80211_MAX_SSID_LEN]; s8 default_key, default_mgmt_key; bool prev_bssid_valid; } wext; #endif; struct wiphy_work cqm_rssi_work; struct cfg80211_cqm_config *cqm_config; struct list_head pmsr_list; spinlock_t pmsr_lock; struct work_struct pmsr_free_wk; unsigned long unprot_beacon_reported; union { struct { u8 connected_addr[ETH_ALEN]; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } client; struct { int beacon_interval; struct cfg80211_chan_def preset_chandef; struct cfg80211_chan_def chandef; u8 id[IEEE80211_MAX_MESH_ID_LEN]; u8 id_len, id_up_len; } mesh; struct { struct cfg80211_chan_def preset_chandef; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } ap; struct { struct cfg80211_internal_bss *current_bss; struct cfg80211_chan_def chandef; int beacon_interval; u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; } ibss; struct { struct cfg80211_chan_def chandef; } ocb; struct { u8 cluster_id[ETH_ALEN]; u8 n_channels; struct cfg80211_chan_def *chandefs; bool sched_update_pending; } nan; } u; struct { u8 addr[ETH_ALEN]; union { struct { unsigned int beacon_interval; struct cfg80211_chan_def chandef; } ap; struct { struct cfg80211_internal_bss *current_bss; } client; }; bool cac_started; unsigned long cac_start_time; unsigned int cac_time_ms; } links[IEEE80211_MLD_MAX_NUM_LINKS]; u16 valid_links; u32 radio_mask; };}hjRsbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjRubh)}(h **Members**h]j)}(hjRh]hMembers}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMRhjRubj%)}(hhh](j*)}(h*``wiphy`` pointer to hardware description h](j0)}(h ``wiphy``h]j,)}(hjRh]hwiphy}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjRubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjRubjJ)}(hhh]h)}(hpointer to hardware descriptionh]hpointer to hardware description}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhj ShMhjSubah}(h]h ]h"]h$]h&]uh1jIhjRubeh}(h]h ]h"]h$]h&]uh1j)hj ShMhjRubj*)}(h``iftype`` interface type h](j0)}(h ``iftype``h]j,)}(hj1Sh]hiftype}(hj3ShhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj/Subah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj+SubjJ)}(hhh]h)}(hinterface typeh]hinterface type}(hjJShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFShMhjGSubah}(h]h ]h"]h$]h&]uh1jIhj+Subeh}(h]h ]h"]h$]h&]uh1j)hjFShMhjRubj*)}(h2``list`` (private) Used to collect the interfaces h](j0)}(h``list``h]j,)}(hjjSh]hlist}(hjlShhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjhSubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjdSubjJ)}(hhh]h)}(h((private) Used to collect the interfacesh]h((private) Used to collect the interfaces}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShMhjSubah}(h]h ]h"]h$]h&]uh1jIhjdSubeh}(h]h ]h"]h$]h&]uh1j)hjShMhjRubj*)}(hK``netdev`` (private) Used to reference back to the netdev, may be ``NULL`` h](j0)}(h ``netdev``h]j,)}(hjSh]hnetdev}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjSubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjSubjJ)}(hhh]h)}(h?(private) Used to reference back to the netdev, may be ``NULL``h](h7(private) Used to reference back to the netdev, may be }(hjShhhNhNubj,)}(h``NULL``h]hNULL}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjSubeh}(h]h ]h"]h$]h&]uh1hhjShMhjSubah}(h]h ]h"]h$]h&]uh1jIhjSubeh}(h]h ]h"]h$]h&]uh1j)hjShMhjRubj*)}(hi``identifier`` (private) Identifier used in nl80211 to identify this wireless device if it has no netdev h](j0)}(h``identifier``h]j,)}(hjSh]h identifier}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjSubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjSubjJ)}(hhh]h)}(hY(private) Identifier used in nl80211 to identify this wireless device if it has no netdevh]hY(private) Identifier used in nl80211 to identify this wireless device if it has no netdev}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjTubah}(h]h ]h"]h$]h&]uh1jIhjSubeh}(h]h ]h"]h$]h&]uh1j)hjShMhjRubj*)}(hC``mgmt_registrations`` list of registrations for management frames h](j0)}(h``mgmt_registrations``h]j,)}(hj$Th]hmgmt_registrations}(hj&ThhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj"Tubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjTubjJ)}(hhh]h)}(h+list of registrations for management framesh]h+list of registrations for management frames}(hj=ThhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9ThMhj:Tubah}(h]h ]h"]h$]h&]uh1jIhjTubeh}(h]h ]h"]h$]h&]uh1j)hj9ThMhjRubj*)}(ho``mgmt_registrations_need_update`` mgmt registrations were updated, need to propagate the update to the driver h](j0)}(h"``mgmt_registrations_need_update``h]j,)}(hj]Th]hmgmt_registrations_need_update}(hj_ThhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj[Tubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjWTubjJ)}(hhh]h)}(hKmgmt registrations were updated, need to propagate the update to the driverh]hKmgmt registrations were updated, need to propagate the update to the driver}(hjvThhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjsTubah}(h]h ]h"]h$]h&]uh1jIhjWTubeh}(h]h ]h"]h$]h&]uh1j)hjrThMhjRubj*)}(h``use_4addr`` indicates 4addr mode is used on this interface, must be set by driver (if supported) on add_interface BEFORE registering the netdev and may otherwise be used by driver read-only, will be update by cfg80211 on change_interface h](j0)}(h ``use_4addr``h]j,)}(hjTh]h use_4addr}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjTubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjTubjJ)}(hhh]h)}(hindicates 4addr mode is used on this interface, must be set by driver (if supported) on add_interface BEFORE registering the netdev and may otherwise be used by driver read-only, will be update by cfg80211 on change_interfaceh]hindicates 4addr mode is used on this interface, must be set by driver (if supported) on add_interface BEFORE registering the netdev and may otherwise be used by driver read-only, will be update by cfg80211 on change_interface}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjTubah}(h]h ]h"]h$]h&]uh1jIhjTubeh}(h]h ]h"]h$]h&]uh1j)hjThMhjRubj*)}(h_``is_running`` true if this is a non-netdev device that has been started, e.g. the P2P Device. h](j0)}(h``is_running``h]j,)}(hjTh]h is_running}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjTubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjTubjJ)}(hhh]h)}(hOtrue if this is a non-netdev device that has been started, e.g. the P2P Device.h]hOtrue if this is a non-netdev device that has been started, e.g. the P2P Device.}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjTubah}(h]h ]h"]h$]h&]uh1jIhjTubeh}(h]h ]h"]h$]h&]uh1j)hjThMhjRubj*)}(h=``registered`` is this wdev already registered with cfg80211 h](j0)}(h``registered``h]j,)}(hj Uh]h registered}(hj UhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj Uubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjUubjJ)}(hhh]h)}(h-is this wdev already registered with cfg80211h]h-is this wdev already registered with cfg80211}(hj$UhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj UhMhj!Uubah}(h]h ]h"]h$]h&]uh1jIhjUubeh}(h]h ]h"]h$]h&]uh1j)hj UhMhjRubj*)}(hU``registering`` indicates we're doing registration under wiphy lock for the notifier h](j0)}(h``registering``h]j,)}(hjDUh]h registering}(hjFUhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjBUubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj>UubjJ)}(hhh]h)}(hDindicates we're doing registration under wiphy lock for the notifierh]hFindicates we’re doing registration under wiphy lock for the notifier}(hj]UhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjZUubah}(h]h ]h"]h$]h&]uh1jIhj>Uubeh}(h]h ]h"]h$]h&]uh1j)hjYUhMhjRubj*)}(hN``address`` The address for this device, valid only if **netdev** is ``NULL`` h](j0)}(h ``address``h]j,)}(hj~Uh]haddress}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj|Uubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjxUubjJ)}(hhh]h)}(hAThe address for this device, valid only if **netdev** is ``NULL``h](h+The address for this device, valid only if }(hjUhhhNhNubj)}(h **netdev**h]hnetdev}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubh is }(hjUhhhNhNubj,)}(h``NULL``h]hNULL}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjUubeh}(h]h ]h"]h$]h&]uh1hhjUhMhjUubah}(h]h ]h"]h$]h&]uh1jIhjxUubeh}(h]h ]h"]h$]h&]uh1j)hjUhMhjRubj*)}(hG``conn`` (private) cfg80211 software SME connection state machine data h](j0)}(h``conn``h]j,)}(hjUh]hconn}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjUubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjUubjJ)}(hhh]h)}(h=(private) cfg80211 software SME connection state machine datah]h=(private) cfg80211 software SME connection state machine data}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhM hjUubah}(h]h ]h"]h$]h&]uh1jIhjUubeh}(h]h ]h"]h$]h&]uh1j)hjUhM hjRubj*)}(hG``connect_keys`` (private) keys to set after connection is established h](j0)}(h``connect_keys``h]j,)}(hjVh]h connect_keys}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjVubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM!hj VubjJ)}(hhh]h)}(h5(private) keys to set after connection is establishedh]h5(private) keys to set after connection is established}(hj)VhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%VhM!hj&Vubah}(h]h ]h"]h$]h&]uh1jIhj Vubeh}(h]h ]h"]h$]h&]uh1j)hj%VhM!hjRubj*)}(h0``conn_bss_type`` connecting/connected BSS type h](j0)}(h``conn_bss_type``h]j,)}(hjIVh]h conn_bss_type}(hjKVhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjGVubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM"hjCVubjJ)}(hhh]h)}(hconnecting/connected BSS typeh]hconnecting/connected BSS type}(hjbVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^VhM"hj_Vubah}(h]h ]h"]h$]h&]uh1jIhjCVubeh}(h]h ]h"]h$]h&]uh1j)hj^VhM"hjRubj*)}(hB``conn_owner_nlportid`` (private) connection owner socket port ID h](j0)}(h``conn_owner_nlportid``h]j,)}(hjVh]hconn_owner_nlportid}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjVubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM#hj|VubjJ)}(hhh]h)}(h)(private) connection owner socket port IDh]h)(private) connection owner socket port ID}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhM#hjVubah}(h]h ]h"]h$]h&]uh1jIhj|Vubeh}(h]h ]h"]h$]h&]uh1j)hjVhM#hjRubj*)}(h1``disconnect_wk`` (private) auto-disconnect work h](j0)}(h``disconnect_wk``h]j,)}(hjVh]h disconnect_wk}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjVubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM$hjVubjJ)}(hhh]h)}(h(private) auto-disconnect workh]h(private) auto-disconnect work}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhM$hjVubah}(h]h ]h"]h$]h&]uh1jIhjVubeh}(h]h ]h"]h$]h&]uh1j)hjVhM$hjRubj*)}(hD``disconnect_bssid`` (private) the BSSID to use for auto-disconnect h](j0)}(h``disconnect_bssid``h]j,)}(hjVh]hdisconnect_bssid}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjVubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM%hjVubjJ)}(hhh]h)}(h.(private) the BSSID to use for auto-disconnecth]h.(private) the BSSID to use for auto-disconnect}(hj WhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj WhM%hj Wubah}(h]h ]h"]h$]h&]uh1jIhjVubeh}(h]h ]h"]h$]h&]uh1j)hj WhM%hjRubj*)}(h<``event_list`` (private) list for internal event processing h](j0)}(h``event_list``h]j,)}(hj-Wh]h event_list}(hj/WhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj+Wubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM&hj'WubjJ)}(hhh]h)}(h,(private) list for internal event processingh]h,(private) list for internal event processing}(hjFWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBWhM&hjCWubah}(h]h ]h"]h$]h&]uh1jIhj'Wubeh}(h]h ]h"]h$]h&]uh1j)hjBWhM&hjRubj*)}(h-``event_lock`` (private) lock for event list h](j0)}(h``event_lock``h]j,)}(hjfWh]h event_lock}(hjhWhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjdWubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM'hj`WubjJ)}(hhh]h)}(h(private) lock for event listh]h(private) lock for event list}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{WhM'hj|Wubah}(h]h ]h"]h$]h&]uh1jIhj`Wubeh}(h]h ]h"]h$]h&]uh1j)hj{WhM'hjRubj*)}(h7``connected`` indicates if connected or not (STA mode) h](j0)}(h ``connected``h]j,)}(hjWh]h connected}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjWubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjWubjJ)}(hhh]h)}(h(indicates if connected or not (STA mode)h]h(indicates if connected or not (STA mode)}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhMhjWubah}(h]h ]h"]h$]h&]uh1jIhjWubeh}(h]h ]h"]h$]h&]uh1j)hjWhMhjRubj*)}(h!``ps`` powersave mode is enabled h](j0)}(h``ps``h]j,)}(hjWh]hps}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjWubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjWubjJ)}(hhh]h)}(hpowersave mode is enabledh]hpowersave mode is enabled}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhMhjWubah}(h]h ]h"]h$]h&]uh1jIhjWubeh}(h]h ]h"]h$]h&]uh1j)hjWhMhjRubj*)}(h)``ps_timeout`` dynamic powersave timeout h](j0)}(h``ps_timeout``h]j,)}(hjXh]h ps_timeout}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjXubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj XubjJ)}(hhh]h)}(hdynamic powersave timeouth]hdynamic powersave timeout}(hj*XhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&XhMhj'Xubah}(h]h ]h"]h$]h&]uh1jIhj Xubeh}(h]h ]h"]h$]h&]uh1j)hj&XhMhjRubj*)}(h}``unexpected_nlportid`` (private) netlink port ID of application registered for unexpected frames (AP mode or NAN_DATA mode) h](j0)}(h``unexpected_nlportid``h]j,)}(hjJXh]hunexpected_nlportid}(hjLXhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjHXubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjDXubjJ)}(hhh]h)}(hd(private) netlink port ID of application registered for unexpected frames (AP mode or NAN_DATA mode)h]hd(private) netlink port ID of application registered for unexpected frames (AP mode or NAN_DATA mode)}(hjcXhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj`Xubah}(h]h ]h"]h$]h&]uh1jIhjDXubeh}(h]h ]h"]h$]h&]uh1j)hj_XhMhjRubj*)}(h2``owner_nlportid`` (private) owner socket port ID h](j0)}(h``owner_nlportid``h]j,)}(hjXh]howner_nlportid}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjXubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM(hj~XubjJ)}(hhh]h)}(h(private) owner socket port IDh]h(private) owner socket port ID}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhM(hjXubah}(h]h ]h"]h$]h&]uh1jIhj~Xubeh}(h]h ]h"]h$]h&]uh1j)hjXhM(hjRubj*)}(h3``nl_owner_dead`` (private) owner socket went away h](j0)}(h``nl_owner_dead``h]j,)}(hjXh]h nl_owner_dead}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjXubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM)hjXubjJ)}(hhh]h)}(h (private) owner socket went awayh]h (private) owner socket went away}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhM)hjXubah}(h]h ]h"]h$]h&]uh1jIhjXubeh}(h]h ]h"]h$]h&]uh1j)hjXhM)hjRubj*)}(hH``wext`` (private) Used by the internal wireless extensions compat code h](j0)}(h``wext``h]j,)}(hjXh]hwext}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjXubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjXubjJ)}(hhh]h)}(h>(private) Used by the internal wireless extensions compat codeh]h>(private) Used by the internal wireless extensions compat code}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj YhMhj Yubah}(h]h ]h"]h$]h&]uh1jIhjXubeh}(h]h ]h"]h$]h&]uh1j)hj YhMhjRubj*)}(h8``wext.ibss`` (private) IBSS data part of wext handling h](j0)}(h ``wext.ibss``h]j,)}(hj/Yh]h wext.ibss}(hj1YhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj-Yubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj)YubjJ)}(hhh]h)}(h)(private) IBSS data part of wext handlingh]h)(private) IBSS data part of wext handling}(hjHYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDYhMhjEYubah}(h]h ]h"]h$]h&]uh1jIhj)Yubeh}(h]h ]h"]h$]h&]uh1j)hjDYhMhjRubj*)}(h4``wext.connect`` (private) connection handling data h](j0)}(h``wext.connect``h]j,)}(hjhYh]h wext.connect}(hjjYhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjfYubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjbYubjJ)}(hhh]h)}(h"(private) connection handling datah]h"(private) connection handling data}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}YhMhj~Yubah}(h]h ]h"]h$]h&]uh1jIhjbYubeh}(h]h ]h"]h$]h&]uh1j)hj}YhMhjRubj*)}(h'``wext.keys`` (private) (WEP) key data h](j0)}(h ``wext.keys``h]j,)}(hjYh]h wext.keys}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjYubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjYubjJ)}(hhh]h)}(h(private) (WEP) key datah]h(private) (WEP) key data}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhM hjYubah}(h]h ]h"]h$]h&]uh1jIhjYubeh}(h]h ]h"]h$]h&]uh1j)hjYhM hjRubj*)}(h5``wext.ie`` (private) extra elements for association h](j0)}(h ``wext.ie``h]j,)}(hjYh]hwext.ie}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjYubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjYubjJ)}(hhh]h)}(h((private) extra elements for associationh]h((private) extra elements for association}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhM hjYubah}(h]h ]h"]h$]h&]uh1jIhjYubeh}(h]h ]h"]h$]h&]uh1j)hjYhM hjRubj*)}(h3``wext.ie_len`` (private) length of extra elements h](j0)}(h``wext.ie_len``h]j,)}(hjZh]h wext.ie_len}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjZubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hj ZubjJ)}(hhh]h)}(h"(private) length of extra elementsh]h"(private) length of extra elements}(hj,ZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(ZhM hj)Zubah}(h]h ]h"]h$]h&]uh1jIhj Zubeh}(h]h ]h"]h$]h&]uh1j)hj(ZhM hjRubj*)}(h0``wext.bssid`` (private) selected network BSSID h](j0)}(h``wext.bssid``h]j,)}(hjLZh]h wext.bssid}(hjNZhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjJZubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjFZubjJ)}(hhh]h)}(h (private) selected network BSSIDh]h (private) selected network BSSID}(hjeZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjaZhM hjbZubah}(h]h ]h"]h$]h&]uh1jIhjFZubeh}(h]h ]h"]h$]h&]uh1j)hjaZhM hjRubj*)}(h?``wext.prev_bssid`` (private) previous BSSID for reassociation h](j0)}(h``wext.prev_bssid``h]j,)}(hjZh]hwext.prev_bssid}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjZubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjZubjJ)}(hhh]h)}(h*(private) previous BSSID for reassociationh]h*(private) previous BSSID for reassociation}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhjZubah}(h]h ]h"]h$]h&]uh1jIhjZubeh}(h]h ]h"]h$]h&]uh1j)hjZhMhjRubj*)}(h.``wext.ssid`` (private) selected network SSID h](j0)}(h ``wext.ssid``h]j,)}(hjZh]h wext.ssid}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjZubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM hjZubjJ)}(hhh]h)}(h(private) selected network SSIDh]h(private) selected network SSID}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhM hjZubah}(h]h ]h"]h$]h&]uh1jIhjZubeh}(h]h ]h"]h$]h&]uh1j)hjZhM hjRubj*)}(h:``wext.default_key`` (private) selected default key index h](j0)}(h``wext.default_key``h]j,)}(hjZh]hwext.default_key}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjZubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjZubjJ)}(hhh]h)}(h$(private) selected default key indexh]h$(private) selected default key index}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj [hMhj [ubah}(h]h ]h"]h$]h&]uh1jIhjZubeh}(h]h ]h"]h$]h&]uh1j)hj [hMhjRubj*)}(hJ``wext.default_mgmt_key`` (private) selected default management key index h](j0)}(h``wext.default_mgmt_key``h]j,)}(hj0[h]hwext.default_mgmt_key}(hj2[hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj.[ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj*[ubjJ)}(hhh]h)}(h/(private) selected default management key indexh]h/(private) selected default management key index}(hjI[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjE[hMhjF[ubah}(h]h ]h"]h$]h&]uh1jIhj*[ubeh}(h]h ]h"]h$]h&]uh1j)hjE[hMhjRubj*)}(h<``wext.prev_bssid_valid`` (private) previous BSSID validity h](j0)}(h``wext.prev_bssid_valid``h]j,)}(hji[h]hwext.prev_bssid_valid}(hjk[hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjg[ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjc[ubjJ)}(hhh]h)}(h!(private) previous BSSID validityh]h!(private) previous BSSID validity}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~[hMhj[ubah}(h]h ]h"]h$]h&]uh1jIhjc[ubeh}(h]h ]h"]h$]h&]uh1j)hj~[hMhjRubj*)}(h4``cqm_rssi_work`` (private) CQM RSSI reporting work h](j0)}(h``cqm_rssi_work``h]j,)}(hj[h]h cqm_rssi_work}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj[ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM*hj[ubjJ)}(hhh]h)}(h!(private) CQM RSSI reporting workh]h!(private) CQM RSSI reporting work}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hM*hj[ubah}(h]h ]h"]h$]h&]uh1jIhj[ubeh}(h]h ]h"]h$]h&]uh1j)hj[hM*hjRubj*)}(h4``cqm_config`` (private) nl80211 RSSI monitor state h](j0)}(h``cqm_config``h]j,)}(hj[h]h cqm_config}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj[ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM+hj[ubjJ)}(hhh]h)}(h$(private) nl80211 RSSI monitor stateh]h$(private) nl80211 RSSI monitor state}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hM+hj[ubah}(h]h ]h"]h$]h&]uh1jIhj[ubeh}(h]h ]h"]h$]h&]uh1j)hj[hM+hjRubj*)}(h2``pmsr_list`` (private) peer measurement requests h](j0)}(h ``pmsr_list``h]j,)}(hj\h]h pmsr_list}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj\ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM,hj\ubjJ)}(hhh]h)}(h#(private) peer measurement requestsh]h#(private) peer measurement requests}(hj-\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)\hM,hj*\ubah}(h]h ]h"]h$]h&]uh1jIhj\ubeh}(h]h ]h"]h$]h&]uh1j)hj)\hM,hjRubj*)}(h@``pmsr_lock`` (private) peer measurements requests/results lock h](j0)}(h ``pmsr_lock``h]j,)}(hjM\h]h pmsr_lock}(hjO\hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjK\ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM-hjG\ubjJ)}(hhh]h)}(h1(private) peer measurements requests/results lockh]h1(private) peer measurements requests/results lock}(hjf\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjb\hM-hjc\ubah}(h]h ]h"]h$]h&]uh1jIhjG\ubeh}(h]h ]h"]h$]h&]uh1j)hjb\hM-hjRubj*)}(h:``pmsr_free_wk`` (private) peer measurements cleanup work h](j0)}(h``pmsr_free_wk``h]j,)}(hj\h]h pmsr_free_wk}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj\ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM.hj\ubjJ)}(hhh]h)}(h((private) peer measurements cleanup workh]h((private) peer measurements cleanup work}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\hM.hj\ubah}(h]h ]h"]h$]h&]uh1jIhj\ubeh}(h]h ]h"]h$]h&]uh1j)hj\hM.hjRubj*)}(hQ``unprot_beacon_reported`` (private) timestamp of last unprotected beacon report h](j0)}(h``unprot_beacon_reported``h]j,)}(hj\h]hunprot_beacon_reported}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj\ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM0hj\ubjJ)}(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.hhM/hj\ubah}(h]h ]h"]h$]h&]uh1jIhj\ubeh}(h]h ]h"]h$]h&]uh1j)hj\hM0hjRubj*)}(h3``u`` union containing data specific to **iftype** h](j0)}(h``u``h]j,)}(hj\h]hu}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj\ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj\ubjJ)}(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&]uh1jhj]ubeh}(h]h ]h"]h$]h&]uh1hhj]hMhj]ubah}(h]h ]h"]h$]h&]uh1jIhj\ubeh}(h]h ]h"]h$]h&]uh1j)hj]hMhjRubj*)}(ht``links`` array of ``IEEE80211_MLD_MAX_NUM_LINKS`` elements containing **addr** **ap** and **client** for each link h](j0)}(h ``links``h]j,)}(hj@]h]hlinks}(hjB]hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj>]ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM2hj:]ubjJ)}(hhh]h)}(hiarray of ``IEEE80211_MLD_MAX_NUM_LINKS`` elements containing **addr** **ap** and **client** for each linkh](h array of }(hjY]hhhNhNubj,)}(h``IEEE80211_MLD_MAX_NUM_LINKS``h]hIEEE80211_MLD_MAX_NUM_LINKS}(hja]hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjY]ubh elements containing }(hjY]hhhNhNubj)}(h**addr**h]haddr}(hjs]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjY]ubh }(hjY]hhhNhNubj)}(h**ap**h]hap}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjY]ubh and }(hjY]hhhNhNubj)}(h **client**h]hclient}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjY]ubh for each link}(hjY]hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM1hjV]ubah}(h]h ]h"]h$]h&]uh1jIhj:]ubeh}(h]h ]h"]h$]h&]uh1j)hjU]hM2hjRubj*)}(h``{unnamed_union}`` anonymous h](j0)}(h``{unnamed_union}``h]j,)}(hj]h]h{unnamed_union}}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj]ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhKhj]ubjJ)}(hhh]h)}(h anonymoush]h anonymous}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hKhj]ubah}(h]h ]h"]h$]h&]uh1jIhj]ubeh}(h]h ]h"]h$]h&]uh1j)hj]hKhjRubj*)}(hN``links.cac_started`` true if DFS channel availability check has been started h](j0)}(h``links.cac_started``h]j,)}(hj]h]hlinks.cac_started}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj]ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM4hj]ubjJ)}(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.hhM3hj^ubah}(h]h ]h"]h$]h&]uh1jIhj]ubeh}(h]h ]h"]h$]h&]uh1j)hj^hM4hjRubj*)}(hM``links.cac_start_time`` timestamp (jiffies) when the dfs state was entered. h](j0)}(h``links.cac_start_time``h]j,)}(hj5^h]hlinks.cac_start_time}(hj7^hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj3^ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6hj/^ubjJ)}(hhh]h)}(h3timestamp (jiffies) when the dfs state was entered.h]h3timestamp (jiffies) when the dfs state was entered.}(hjN^hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM5hjK^ubah}(h]h ]h"]h$]h&]uh1jIhj/^ubeh}(h]h ]h"]h$]h&]uh1j)hjJ^hM6hjRubj*)}(h%``links.cac_time_ms`` CAC time in ms h](j0)}(h``links.cac_time_ms``h]j,)}(hjo^h]hlinks.cac_time_ms}(hjq^hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjm^ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM7hji^ubjJ)}(hhh]h)}(hCAC time in msh]hCAC time in ms}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hM7hj^ubah}(h]h ]h"]h$]h&]uh1jIhji^ubeh}(h]h ]h"]h$]h&]uh1j)hj^hM7hjRubj*)}(hG``valid_links`` bitmap describing what elements of **links** are valid h](j0)}(h``valid_links``h]j,)}(hj^h]h valid_links}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj^ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM8hj^ubjJ)}(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&]uh1jhj^ubh are valid}(hj^hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj^hM8hj^ubah}(h]h ]h"]h$]h&]uh1jIhj^ubeh}(h]h ]h"]h$]h&]uh1j)hj^hM8hjRubj*)}(hN``radio_mask`` Bitmask of radios that this interface is allowed to operate on.h](j0)}(h``radio_mask``h]j,)}(hj^h]h radio_mask}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj^ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM8hj^ubjJ)}(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.hhM9hj _ubah}(h]h ]h"]h$]h&]uh1jIhj^ubeh}(h]h ]h"]h$]h&]uh1j)hj_hM8hjRubeh}(h]h ]h"]h$]h&]uh1j$hjRubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(h**Description**h]j)}(hj6_h]h Description}(hj8_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4_ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM<hhhhubh)}(hXFor netdevs, this structure must be allocated by the driver that uses the ieee80211_ptr field in struct net_device (this is intentional so it can be allocated along with the netdev.) It need not be registered then as netdev registration will be intercepted by cfg80211 to see the new wireless device, however, drivers must lock the wiphy before registering or unregistering netdevs if they pre-create any netdevs (in ops called from cfg80211, the wiphy is already locked.)h]hXFor netdevs, this structure must be allocated by the driver that uses the ieee80211_ptr field in struct net_device (this is intentional so it can be allocated along with the netdev.) It need not be registered then as netdev registration will be intercepted by cfg80211 to see the new wireless device, however, drivers must lock the wiphy before registering or unregistering netdevs if they pre-create any netdevs (in ops called from cfg80211, the wiphy is already locked.)}(hjL_hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhhhhubh)}(hFor non-netdev uses, it must also be allocated by the driver in response to the cfg80211 callbacks that require it, as there's no netdev registration in that case it may not be allocated outside of callback operations that return it.h]hFor non-netdev uses, it must also be allocated by the driver in response to the cfg80211 callbacks that require it, as there’s no netdev registration in that case it may not be allocated outside of callback operations that return it.}(hj[_hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhhhhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jswdev_priv (C function) c.wdev_privhNtauh1jfhhhhhNhNubjx)}(hhh](j})}(h,void * wdev_priv (struct wireless_dev *wdev)h]j)}(h*void *wdev_priv(struct wireless_dev *wdev)h](j)}(hvoidh]hvoid}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMubj)}(h h]h }(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_hhhj_hMubjz)}(hj}h]h*}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj_hhhj_hMubj)}(h wdev_privh]j)}(h wdev_privh]h wdev_priv}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj_hhhj_hMubj)}(h(struct wireless_dev *wdev)h]j%)}(hstruct wireless_dev *wdevh](j)}(hjh]hstruct}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_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&] refdomainj8reftypej^ reftargetj_modnameN classnameNj j )}j ]jf)}j^j_sb c.wdev_privasbuh1hhj_ubj)}(h h]h }(hj `hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_ubjz)}(hj}h]h*}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj_ubj)}(hwdevh]hwdev}(hj&`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj_ubah}(h]h ]h"]h$]h&]jjuh1jhj_hhhj_hMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj{_hhhj_hMubah}(h]jv_ah ](jjeh"]h$]h&]jj)jhuh1j|hj_hMhjx_hhubj)}(hhh]h)}(h#return wiphy priv from wireless_devh]h#return wiphy priv from wireless_dev}(hjP`hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjM`hhubah}(h]h ]h"]h$]h&]uh1jhjx_hhhj_hMubeh}(h]h ](j8functioneh"]h$]h&]jj8jjh`jjh`jjjuh1jwhhhhhNhNubj)}(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)}(hjr`h]h Parameters}(hjt`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjp`ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjl`ubj%)}(hhh]j*)}(hW``struct wireless_dev *wdev`` The wireless device whose wiphy's priv pointer to return h](j0)}(h``struct wireless_dev *wdev``h]j,)}(hj`h]hstruct wireless_dev *wdev}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj`ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhj`ubjJ)}(hhh]h)}(h8The wireless device whose wiphy's priv pointer to returnh]h:The wireless device whose wiphy’s priv pointer to return}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hMhj`ubah}(h]h ]h"]h$]h&]uh1jIhj`ubeh}(h]h ]h"]h$]h&]uh1j)hj`hMhj`ubah}(h]h ]h"]h$]h&]uh1j$hjl`ubh)}(h **Return**h]j)}(hj`h]hReturn}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhMhjl`ubh)}(hThe wiphy priv of **wdev**.h](hThe wiphy priv of }(hj`hhhNhNubj)}(h**wdev**h]hwdev}(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:14: ./include/net/cfg80211.hhMhjl`ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js(cfg80211_check_combinations (C function)c.cfg80211_check_combinationshNtauh1jfhhhhhNhNubjx)}(hhh](j})}(h^int cfg80211_check_combinations (struct wiphy *wiphy, struct iface_combination_params *params)h]j)}(h]int cfg80211_check_combinations(struct wiphy *wiphy, struct iface_combination_params *params)h](j)}(hinth]hint}(hj#ahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjahhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM1'ubj)}(h h]h }(hj2ahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjahhhj1ahM1'ubj)}(hcfg80211_check_combinationsh]j)}(hcfg80211_check_combinationsh]hcfg80211_check_combinations}(hjDahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@aubah}(h]h ](jjeh"]h$]h&]jjuh1jhjahhhj1ahM1'ubj)}(h>(struct wiphy *wiphy, struct iface_combination_params *params)h](j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hj`ahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\aubj)}(h h]h }(hjmahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\aubh)}(hhh]j)}(hwiphyh]hwiphy}(hj~ahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{aubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjamodnameN classnameNj j )}j ]jf)}j^jFasbc.cfg80211_check_combinationsasbuh1hhj\aubj)}(h h]h }(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\aubjz)}(hj}h]h*}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj\aubj)}(hwiphyh]hwiphy}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\aubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjXaubj%)}(h'struct iface_combination_params *paramsh](j)}(hjh]hstruct}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubj)}(h h]h }(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubh)}(hhh]j)}(hiface_combination_paramsh]hiface_combination_params}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjamodnameN classnameNj j )}j ]jac.cfg80211_check_combinationsasbuh1hhjaubj)}(h h]h }(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjaubjz)}(hj}h]h*}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjaubj)}(hparamsh]hparams}(hj)bhhhNhNubah}(h] h ]jah"]h$]h&]uh1jhjaubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjXaubeh}(h]h ]h"]h$]h&]jjuh1jhjahhhj1ahM1'ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjahhhj1ahM1'ubah}(h]jaah ](jjeh"]h$]h&]jj)jhuh1j|hj1ahM1'hjahhubj)}(hhh]h)}(hcheck interface combinationsh]hcheck interface combinations}(hjSbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM1'hjPbhhubah}(h]h ]h"]h$]h&]uh1jhjahhhj1ahM1'ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjkbjjkbjjjuh1jwhhhhhNhNubj)}(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)}(hjubh]h Parameters}(hjwbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsbubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM5'hjobubj%)}(hhh](j*)}(h"``struct wiphy *wiphy`` the wiphy h](j0)}(h``struct wiphy *wiphy``h]j,)}(hjbh]hstruct wiphy *wiphy}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjbubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM3'hjbubjJ)}(hhh]h)}(h the wiphyh]h the wiphy}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhM3'hjbubah}(h]h ]h"]h$]h&]uh1jIhjbubeh}(h]h ]h"]h$]h&]uh1j)hjbhM3'hjbubj*)}(hQ``struct iface_combination_params *params`` the interface combinations parameter h](j0)}(h+``struct iface_combination_params *params``h]j,)}(hjbh]h'struct iface_combination_params *params}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjbubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM4'hjbubjJ)}(hhh]h)}(h$the interface combinations parameterh]h$the interface combinations parameter}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhM4'hjbubah}(h]h ]h"]h$]h&]uh1jIhjbubeh}(h]h ]h"]h$]h&]uh1j)hjbhM4'hjbubeh}(h]h ]h"]h$]h&]uh1j$hjobubh)}(h**Description**h]j)}(hjch]h Description}(hj chhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM6'hjobubh)}(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.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM5'hjobubh)}(h **Return**h]j)}(hj/ch]hReturn}(hj1chhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-cubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM9'hjobubh)}(h10 if combinations are allowed. Non-zero on error.h]h10 if combinations are allowed. Non-zero on error.}(hjEchhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:14: ./include/net/cfg80211.hhM:'hjobubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubeh}(h]device-registrationah ]h"]device registrationah$]h&]uh1hhhhhhhhK ubh)}(hhh](h)}(hActions and configurationh]hActions and configuration}(hjfchhhNhNubah}(h]h ]h"]h$]h&]uh1hhjcchhhhhK+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.}(hjtchhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:45: ./include/net/cfg80211.hhM hjcchhubh)}(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.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:45: ./include/net/cfg80211.hhMhjcchhubh)}(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.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:45: ./include/net/cfg80211.hhMhjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsvif_params (C struct) c.vif_paramshNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(h vif_paramsh]j)}(hstruct vif_paramsh](j)}(hjh]hstruct}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjchhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhKubj)}(h h]h }(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjchhhjchKubj)}(h vif_paramsh]j)}(hjch]h vif_params}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubah}(h]h ](jjeh"]h$]h&]jjuh1jhjchhhjchKubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjchhhjchKubah}(h]jcah ](jjeh"]h$]h&]jj)jhuh1j|hjchKhjchhubj)}(hhh]h)}(h&describes virtual interface parametersh]h&describes virtual interface parameters}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjchhubah}(h]h ]h"]h$]h&]uh1jhjchhhjchKubeh}(h]h ](j8structeh"]h$]h&]jj8jjdjjdjjjuh1jwhhhjcchNhNubj)}(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}(hj dhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubh:}(hjdhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjdubj: )}(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; };}hj9dsbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hjdubh)}(h **Members**h]j)}(hjJdh]hMembers}(hjLdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHdubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM+hjdubj%)}(hhh](j*)}(hb``flags`` monitor interface flags, unchanged if 0, otherwise ``MONITOR_FLAG_CHANGED`` will be set h](j0)}(h ``flags``h]j,)}(hjidh]hflags}(hjkdhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjgdubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcdubjJ)}(hhh]h)}(hWmonitor interface flags, unchanged if 0, otherwise ``MONITOR_FLAG_CHANGED`` will be seth](h3monitor interface flags, unchanged if 0, otherwise }(hjdhhhNhNubj,)}(h``MONITOR_FLAG_CHANGED``h]hMONITOR_FLAG_CHANGED}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjdubh will be set}(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&]uh1jIhjcdubeh}(h]h ]h"]h$]h&]uh1j)hj~dhM hj`dubj*)}(h#``use_4addr`` use 4-address frames h](j0)}(h ``use_4addr``h]j,)}(hjdh]h use_4addr}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjdubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjdubjJ)}(hhh]h)}(huse 4-address framesh]huse 4-address frames}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdhM!hjdubah}(h]h ]h"]h$]h&]uh1jIhjdubeh}(h]h ]h"]h$]h&]uh1j)hjdhM!hj`dubj*)}(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](j0)}(h ``macaddr``h]j,)}(hjdh]hmacaddr}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjdubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM'hjdubjJ)}(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 }(hjehhhNhNubj,)}(h!``NL80211_FEATURE_MAC_ON_CREATE``h]hNL80211_FEATURE_MAC_ON_CREATE}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjeubhN flag. Others may support creating * only p2p devices with specified MAC.}(hjehhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjeubah}(h]h ]h"]h$]h&]uh1jIhjdubeh}(h]h ]h"]h$]h&]uh1j)hjehM'hj`dubj*)}(h``vht_mumimo_groups`` MU-MIMO groupID, used for monitoring MU-MIMO packets belonging to that MU-MIMO groupID; ``NULL`` if not changed h](j0)}(h``vht_mumimo_groups``h]j,)}(hj:eh]hvht_mumimo_groups}(hjhjfubjJ)}(hhh]h)}(hPsequence counter (IV/PN), must be in little endian, length given by **seq_len**.h](hDsequence counter (IV/PN), must be in little endian, length given by }(hjfhhhNhNubj)}(h **seq_len**h]hseq_len}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubh.}(hjfhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM=hjfubah}(h]h ]h"]h$]h&]uh1jIhjfubeh}(h]h ]h"]h$]h&]uh1j)hjfhM>hjfubj*)}(h#``key_len`` length of key material h](j0)}(h ``key_len``h]j,)}(hj%gh]hkey_len}(hj'ghhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj#gubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM;hjgubjJ)}(hhh]h)}(hlength of key materialh]hlength of key material}(hj>ghhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:ghM;hj;gubah}(h]h ]h"]h$]h&]uh1jIhjgubeh}(h]h ]h"]h$]h&]uh1j)hj:ghM;hjfubj*)}(h``seq_len`` length of **seq**. h](j0)}(h ``seq_len``h]j,)}(hj^gh]hseq_len}(hj`ghhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj\gubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM?hjXgubjJ)}(hhh]h)}(hlength of **seq**.h](h length of }(hjwghhhNhNubj)}(h**seq**h]hseq}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwgubh.}(hjwghhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjsghM?hjtgubah}(h]h ]h"]h$]h&]uh1jIhjXgubeh}(h]h ]h"]h$]h&]uh1j)hjsghM?hjfubj*)}(h4``vlan_id`` vlan_id for VLAN group key (if nonzero) h](j0)}(h ``vlan_id``h]j,)}(hjgh]hvlan_id}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjgubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM@hjgubjJ)}(hhh]h)}(h'vlan_id for VLAN group key (if nonzero)h]h'vlan_id for VLAN group key (if nonzero)}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghM@hjgubah}(h]h ]h"]h$]h&]uh1jIhjgubeh}(h]h ]h"]h$]h&]uh1j)hjghM@hjfubj*)}(h!``cipher`` cipher suite selector h](j0)}(h ``cipher``h]j,)}(hjgh]hcipher}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjgubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM<hjgubjJ)}(hhh]h)}(hcipher suite selectorh]hcipher suite selector}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghM<hjgubah}(h]h ]h"]h$]h&]uh1jIhjgubeh}(h]h ]h"]h$]h&]uh1j)hjghM<hjfubj*)}(h2``mode`` key install mode (RX_TX, NO_TX or SET_TX)h](j0)}(h``mode``h]j,)}(hjhh]hmode}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjhubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM@hjhubjJ)}(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)}(hj4hhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMAhj1hubah}(h]h ]h"]h$]h&]uh1jIhjhubeh}(h]h ]h"]h$]h&]uh1j)hj0hhM@hjfubeh}(h]h ]h"]h$]h&]uh1j$hjOfubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hj^hh]h Description}(hj`hhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\hubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMDhjcchhubh)}(hInformation about a keyh]hInformation about a key}(hjthhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM6hjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jssurvey_info_flags (C enum)c.survey_info_flagshNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hsurvey_info_flagsh]j)}(henum survey_info_flagsh](j)}(hjh]henum}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM;ubj)}(h h]h }(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhhjhhM;ubj)}(hsurvey_info_flagsh]j)}(hjhh]hsurvey_info_flags}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhhjhhM;ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhhjhhM;ubah}(h]jhah ](jjeh"]h$]h&]jj)jhuh1j|hjhhM;hjhhhubj)}(hhh]h)}(hsurvey information flagsh]hsurvey information flags}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhhhubah}(h]h ]h"]h$]h&]uh1jhjhhhhjhhM;ubeh}(h]h ](j8enumeh"]h$]h&]jj8jjhjjhjjjuh1jwhhhjcchNhNubj)}(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)}(hjih]h Constants}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhubj%)}(hhh](j*)}(h7``SURVEY_INFO_NOISE_DBM`` noise (in dBm) was filled in h](j0)}(h``SURVEY_INFO_NOISE_DBM``h]j,)}(hjih]hSURVEY_INFO_NOISE_DBM}(hj!ihhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjiubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjiubjJ)}(hhh]h)}(hnoise (in dBm) was filled inh]hnoise (in dBm) was filled in}(hj8ihhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4ihMhj5iubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j)hj4ihMhjiubj*)}(h7``SURVEY_INFO_IN_USE`` channel is currently being used h](j0)}(h``SURVEY_INFO_IN_USE``h]j,)}(hjXih]hSURVEY_INFO_IN_USE}(hjZihhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjViubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjRiubjJ)}(hhh]h)}(hchannel is currently being usedh]hchannel is currently being used}(hjqihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmihMhjniubah}(h]h ]h"]h$]h&]uh1jIhjRiubeh}(h]h ]h"]h$]h&]uh1j)hjmihMhjiubj*)}(h7``SURVEY_INFO_TIME`` active time (in ms) was filled in h](j0)}(h``SURVEY_INFO_TIME``h]j,)}(hjih]hSURVEY_INFO_TIME}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjiubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjiubjJ)}(hhh]h)}(h!active time (in ms) was filled inh]h!active time (in ms) was filled in}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhjiubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j)hjihMhjiubj*)}(h2``SURVEY_INFO_TIME_BUSY`` busy time was filled in h](j0)}(h``SURVEY_INFO_TIME_BUSY``h]j,)}(hjih]hSURVEY_INFO_TIME_BUSY}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjiubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjiubjJ)}(hhh]h)}(hbusy time was filled inh]hbusy time was filled in}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhjiubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j)hjihMhjiubj*)}(hH``SURVEY_INFO_TIME_EXT_BUSY`` extension channel busy time was filled in h](j0)}(h``SURVEY_INFO_TIME_EXT_BUSY``h]j,)}(hjjh]hSURVEY_INFO_TIME_EXT_BUSY}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjiubjJ)}(hhh]h)}(h)extension channel busy time was filled inh]h)extension channel busy time was filled in}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjhMhjjubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j)hjjhMhjiubj*)}(h3``SURVEY_INFO_TIME_RX`` receive time was filled in h](j0)}(h``SURVEY_INFO_TIME_RX``h]j,)}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj:jubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj6jubjJ)}(hhh]h)}(hreceive time was filled inh]hreceive time was filled in}(hjUjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQjhMhjRjubah}(h]h ]h"]h$]h&]uh1jIhj6jubeh}(h]h ]h"]h$]h&]uh1j)hjQjhMhjiubj*)}(h4``SURVEY_INFO_TIME_TX`` transmit time was filled in h](j0)}(h``SURVEY_INFO_TIME_TX``h]j,)}(hjujh]hSURVEY_INFO_TIME_TX}(hjwjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjsjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjojubjJ)}(hhh]h)}(htransmit time was filled inh]htransmit time was filled in}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjhMhjjubah}(h]h ]h"]h$]h&]uh1jIhjojubeh}(h]h ]h"]h$]h&]uh1j)hjjhMhjiubj*)}(h2``SURVEY_INFO_TIME_SCAN`` scan time was filled in h](j0)}(h``SURVEY_INFO_TIME_SCAN``h]j,)}(hjjh]hSURVEY_INFO_TIME_SCAN}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubjJ)}(hhh]h)}(hscan time was filled inh]hscan time was filled in}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjhMhjjubah}(h]h ]h"]h$]h&]uh1jIhjjubeh}(h]h ]h"]h$]h&]uh1j)hjjhMhjiubj*)}(h@``SURVEY_INFO_TIME_BSS_RX`` local BSS receive time was filled inh](j0)}(h``SURVEY_INFO_TIME_BSS_RX``h]j,)}(hjjh]hSURVEY_INFO_TIME_BSS_RX}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubjJ)}(hhh]h)}(h$local BSS receive time was filled inh]h$local BSS receive time was filled in}(hjkhhhNhNubah}(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&]uh1jIhjjubeh}(h]h ]h"]h$]h&]uh1j)hjjhMhjiubeh}(h]h ]h"]h$]h&]uh1j$hjhubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hj*kh]h Description}(hj,khhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(kubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubh)}(hUsed by the driver to indicate which info in :c:type:`struct survey_info ` it has filled in during the get_survey().h](h-Used by the driver to indicate which info in }(hj@khhhNhNubh)}(h*:c:type:`struct survey_info `h]j,)}(hjJkh]hstruct survey_info}(hjLkhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjHkubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJ survey_infouh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj@kubh* it has filled in during the get_survey().}(hj@khhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjgkhMhjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jssurvey_info (C struct) c.survey_infohNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(h survey_infoh]j)}(hstruct survey_infoh](j)}(hjh]hstruct}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkhhhjkhMubj)}(h survey_infoh]j)}(hjkh]h survey_info}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkubah}(h]h ](jjeh"]h$]h&]jjuh1jhjkhhhjkhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjkhhhjkhMubah}(h]j~kah ](jjeh"]h$]h&]jj)jhuh1j|hjkhMhjkhhubj)}(hhh]h)}(hchannel survey responseh]hchannel survey response}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjkhhubah}(h]h ]h"]h$]h&]uh1jhjkhhhjkhMubeh}(h]h ](j8structeh"]h$]h&]jj8jjkjjkjjjuh1jwhhhjcchNhNubj)}(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}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubh:}(hjkhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjkubj: )}(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; };}hj lsbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjkubh)}(h **Members**h]j)}(hjlh]hMembers}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjkubj%)}(hhh](j*)}(ht``channel`` the channel this survey record reports, may be ``NULL`` for a single record to report global statistics h](j0)}(h ``channel``h]j,)}(hj:lh]hchannel}(hj` h](j0)}(h ``filled``h]j,)}(hjnh]hfilled}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjnubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnubjJ)}(hhh]h)}(hJbitflag of flags from :c:type:`enum survey_info_flags `h](hbitflag of flags from }(hj.nhhhNhNubh)}(h4:c:type:`enum survey_info_flags `h]j,)}(hj8nh]henum survey_info_flags}(hj:nhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj6nubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJsurvey_info_flagsuh1hhj*nhMhj.nubeh}(h]h ]h"]h$]h&]uh1hhj*nhMhj+nubah}(h]h ]h"]h$]h&]uh1jIhjnubeh}(h]h ]h"]h$]h&]uh1j)hj*nhMhj1lubj*)}(hJ``noise`` channel noise in dBm. This and all following fields are optionalh](j0)}(h ``noise``h]j,)}(hjmnh]hnoise}(hjonhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjknubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjgnubjJ)}(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}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhMhjnubah}(h]h ]h"]h$]h&]uh1jIhjgnubeh}(h]h ]h"]h$]h&]uh1j)hjnhMhj1lubeh}(h]h ]h"]h$]h&]uh1j$hjkubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjnh]h Description}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubh)}(hDUsed by dump_survey() to report back per-channel survey information.h]hDUsed by dump_survey() to report back per-channel survey information.}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubh)}(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.}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js#cfg80211_crypto_settings (C struct)c.cfg80211_crypto_settingshNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hcfg80211_crypto_settingsh]j)}(hstruct cfg80211_crypto_settingsh](j)}(hjh]hstruct}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hj ohhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnhhhj ohMubj)}(hcfg80211_crypto_settingsh]j)}(hjnh]hcfg80211_crypto_settings}(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoubah}(h]h ](jjeh"]h$]h&]jjuh1jhjnhhhj ohMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjnhhhj ohMubah}(h]jnah ](jjeh"]h$]h&]jj)jhuh1j|hj ohMhjnhhubj)}(hhh]h)}(hCrypto settingsh]hCrypto settings}(hj>ohhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj;ohhubah}(h]h ]h"]h$]h&]uh1jhjnhhhj ohMubeh}(h]h ](j8structeh"]h$]h&]jj8jjVojjVojjjuh1jwhhhjcchNhNubj)}(hX**Definition**:: struct cfg80211_crypto_settings { u32 wpa_versions; u32 cipher_group; int n_ciphers_pairwise; u32 ciphers_pairwise[NL80211_MAX_NR_CIPHER_SUITES]; int n_akm_suites; u32 akm_suites[CFG80211_MAX_NUM_AKM_SUITES]; bool control_port; __be16 control_port_ethertype; bool control_port_no_encrypt; bool control_port_over_nl80211; bool control_port_no_preauth; const u8 *psk; const u8 *sae_pwd; u8 sae_pwd_len; enum nl80211_sae_pwe_mechanism sae_pwe; }; **Members** ``wpa_versions`` indicates which, if any, WPA versions are enabled (from enum nl80211_wpa_versions) ``cipher_group`` group key cipher suite (or 0 if unset) ``n_ciphers_pairwise`` number of AP supported unicast ciphers ``ciphers_pairwise`` unicast key cipher suites ``n_akm_suites`` number of AKM suites ``akm_suites`` AKM suites ``control_port`` Whether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default. ``control_port_ethertype`` the control port protocol that should be allowed through even on unauthorized ports ``control_port_no_encrypt`` TRUE to prevent encryption of control port protocol frames. ``control_port_over_nl80211`` TRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface. ``control_port_no_preauth`` disables pre-auth rx over the nl80211 control port for mac80211 ``psk`` PSK (for devices supporting 4-way-handshake offload) ``sae_pwd`` password for SAE authentication (for devices supporting SAE offload) ``sae_pwd_len`` length of SAE password (for devices supporting SAE offload) ``sae_pwe`` The mechanisms allowed for SAE PWE derivation:h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjbohhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^oubh:}(hj^ohhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjZoubj: )}(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{osbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjZoubh)}(h **Members**h]j)}(hjoh]hMembers}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjZoubj%)}(hhh](j*)}(hd``wpa_versions`` indicates which, if any, WPA versions are enabled (from enum nl80211_wpa_versions) h](j0)}(h``wpa_versions``h]j,)}(hjoh]h wpa_versions}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjoubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjoubjJ)}(hhh]h)}(hRindicates which, if any, WPA versions are enabled (from enum nl80211_wpa_versions)h]hRindicates which, if any, WPA versions are enabled (from enum nl80211_wpa_versions)}(hjohhhNhNubah}(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&]uh1jIhjoubeh}(h]h ]h"]h$]h&]uh1j)hjohMhjoubj*)}(h8``cipher_group`` group key cipher suite (or 0 if unset) h](j0)}(h``cipher_group``h]j,)}(hjoh]h cipher_group}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjoubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjoubjJ)}(hhh]h)}(h&group key cipher suite (or 0 if unset)h]h&group key cipher suite (or 0 if unset)}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohMhjoubah}(h]h ]h"]h$]h&]uh1jIhjoubeh}(h]h ]h"]h$]h&]uh1j)hjohMhjoubj*)}(h>``n_ciphers_pairwise`` number of AP supported unicast ciphers h](j0)}(h``n_ciphers_pairwise``h]j,)}(hjph]hn_ciphers_pairwise}(hj phhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjpubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubjJ)}(hhh]h)}(h&number of AP supported unicast ciphersh]h&number of AP supported unicast ciphers}(hj7phhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3phMhj4pubah}(h]h ]h"]h$]h&]uh1jIhjpubeh}(h]h ]h"]h$]h&]uh1j)hj3phMhjoubj*)}(h/``ciphers_pairwise`` unicast key cipher suites h](j0)}(h``ciphers_pairwise``h]j,)}(hjWph]hciphers_pairwise}(hjYphhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjUpubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjQpubjJ)}(hhh]h)}(hunicast key cipher suitesh]hunicast key cipher suites}(hjpphhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlphMhjmpubah}(h]h ]h"]h$]h&]uh1jIhjQpubeh}(h]h ]h"]h$]h&]uh1j)hjlphMhjoubj*)}(h&``n_akm_suites`` number of AKM suites h](j0)}(h``n_akm_suites``h]j,)}(hjph]h n_akm_suites}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjpubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubjJ)}(hhh]h)}(hnumber of AKM suitesh]hnumber of AKM suites}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhjphMhjpubah}(h]h ]h"]h$]h&]uh1jIhjpubeh}(h]h ]h"]h$]h&]uh1j)hjphMhjoubj*)}(h``akm_suites`` AKM suites h](j0)}(h``akm_suites``h]j,)}(hjph]h akm_suites}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjpubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubjJ)}(hhh]h)}(h AKM suitesh]h AKM suites}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhjphMhjpubah}(h]h ]h"]h$]h&]uh1jIhjpubeh}(h]h ]h"]h$]h&]uh1j)hjphMhjoubj*)}(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](j0)}(h``control_port``h]j,)}(hjqh]h control_port}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjqubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjpubjJ)}(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 }(hjqhhhNhNubj,)}(h``NL80211_STA_FLAG_AUTHORIZED``h]hNL80211_STA_FLAG_AUTHORIZED}(hj#qhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjqubh. 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.}(hjqhhhNhNubeh}(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&]uh1jIhjpubeh}(h]h ]h"]h$]h&]uh1j)hjqhMhjoubj*)}(ho``control_port_ethertype`` the control port protocol that should be allowed through even on unauthorized ports h](j0)}(h``control_port_ethertype``h]j,)}(hjNqh]hcontrol_port_ethertype}(hjPqhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjLqubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjHqubjJ)}(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}(hjgqhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjdqubah}(h]h ]h"]h$]h&]uh1jIhjHqubeh}(h]h ]h"]h$]h&]uh1j)hjcqhMhjoubj*)}(hX``control_port_no_encrypt`` TRUE to prevent encryption of control port protocol frames. h](j0)}(h``control_port_no_encrypt``h]j,)}(hjqh]hcontrol_port_no_encrypt}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjqubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubjJ)}(hhh]h)}(h;TRUE to prevent encryption of control port protocol frames.h]h;TRUE to prevent encryption of control port protocol frames.}(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&]uh1jIhjqubeh}(h]h ]h"]h$]h&]uh1j)hjqhMhjoubj*)}(h``control_port_over_nl80211`` TRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface. h](j0)}(h``control_port_over_nl80211``h]j,)}(hjqh]hcontrol_port_over_nl80211}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjqubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubjJ)}(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.}(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&]uh1jIhjqubeh}(h]h ]h"]h$]h&]uh1j)hjqhMhjoubj*)}(h\``control_port_no_preauth`` disables pre-auth rx over the nl80211 control port for mac80211 h](j0)}(h``control_port_no_preauth``h]j,)}(hjqh]hcontrol_port_no_preauth}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjqubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubjJ)}(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}(hjrhhhNhNubah}(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&]uh1jIhjqubeh}(h]h ]h"]h$]h&]uh1j)hjrhMhjoubj*)}(h=``psk`` PSK (for devices supporting 4-way-handshake offload) h](j0)}(h``psk``h]j,)}(hj6rh]hpsk}(hj8rhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj4rubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj0rubjJ)}(hhh]h)}(h4PSK (for devices supporting 4-way-handshake offload)h]h4PSK (for devices supporting 4-way-handshake offload)}(hjOrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKrhMhjLrubah}(h]h ]h"]h$]h&]uh1jIhj0rubeh}(h]h ]h"]h$]h&]uh1j)hjKrhMhjoubj*)}(hQ``sae_pwd`` password for SAE authentication (for devices supporting SAE offload) h](j0)}(h ``sae_pwd``h]j,)}(hjorh]hsae_pwd}(hjqrhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjmrubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjirubjJ)}(hhh]h)}(hDpassword for SAE authentication (for devices supporting SAE offload)h]hDpassword for SAE authentication (for devices supporting SAE offload)}(hjrhhhNhNubah}(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&]uh1jIhjirubeh}(h]h ]h"]h$]h&]uh1j)hjrhMhjoubj*)}(hL``sae_pwd_len`` length of SAE password (for devices supporting SAE offload) h](j0)}(h``sae_pwd_len``h]j,)}(hjrh]h sae_pwd_len}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjrubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjrubjJ)}(hhh]h)}(h;length of SAE password (for devices supporting SAE offload)h]h;length of SAE password (for devices supporting SAE offload)}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrhMhjrubah}(h]h ]h"]h$]h&]uh1jIhjrubeh}(h]h ]h"]h$]h&]uh1j)hjrhMhjoubj*)}(h:``sae_pwe`` The mechanisms allowed for SAE PWE derivation:h](j0)}(h ``sae_pwe``h]j,)}(hjrh]hsae_pwe}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjrubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjrubjJ)}(hhh]h)}(h.The mechanisms allowed for SAE PWE derivation:h]h.The mechanisms allowed for SAE PWE derivation:}(hjrhhhNhNubah}(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&]uh1jIhjrubeh}(h]h ]h"]h$]h&]uh1j)hjrhMhjoubeh}(h]h ]h"]h$]h&]uh1j$hjZoubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hj%sh]h Description}(hj'shhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#subah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubh block_quote)}(hXNL80211_SAE_PWE_UNSPECIFIED Not-specified, used to indicate userspace did not specify any preference. The driver should follow its internal policy in such a scenario. NL80211_SAE_PWE_HUNT_AND_PECK Allow hunting-and-pecking loop only NL80211_SAE_PWE_HASH_TO_ELEMENT Allow hash-to-element only NL80211_SAE_PWE_BOTH Allow either hunting-and-pecking loop or hash-to-element h]j%)}(hhh](j*)}(hNL80211_SAE_PWE_UNSPECIFIED Not-specified, used to indicate userspace did not specify any preference. The driver should follow its internal policy in such a scenario. h](j0)}(hNL80211_SAE_PWE_UNSPECIFIEDh]hNL80211_SAE_PWE_UNSPECIFIED}(hjHshhhNhNubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjDsubjJ)}(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.}(hjZshhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjWsubah}(h]h ]h"]h$]h&]uh1jIhjDsubeh}(h]h ]h"]h$]h&]uh1j)hjVshMhjAsubj*)}(hBNL80211_SAE_PWE_HUNT_AND_PECK Allow hunting-and-pecking loop only h](j0)}(hNL80211_SAE_PWE_HUNT_AND_PECKh]hNL80211_SAE_PWE_HUNT_AND_PECK}(hjyshhhNhNubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjusubjJ)}(hhh]h)}(h#Allow hunting-and-pecking loop onlyh]h#Allow hunting-and-pecking loop only}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshM hjsubah}(h]h ]h"]h$]h&]uh1jIhjusubeh}(h]h ]h"]h$]h&]uh1j)hjshM hjAsubj*)}(h;NL80211_SAE_PWE_HASH_TO_ELEMENT Allow hash-to-element only h](j0)}(hNL80211_SAE_PWE_HASH_TO_ELEMENTh]hNL80211_SAE_PWE_HASH_TO_ELEMENT}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjsubjJ)}(hhh]h)}(hAllow hash-to-element onlyh]hAllow hash-to-element only}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshMhjsubah}(h]h ]h"]h$]h&]uh1jIhjsubeh}(h]h ]h"]h$]h&]uh1j)hjshMhjAsubj*)}(hQNL80211_SAE_PWE_BOTH Allow either hunting-and-pecking loop or hash-to-element h](j0)}(hNL80211_SAE_PWE_BOTHh]hNL80211_SAE_PWE_BOTH}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjsubjJ)}(hhh]h)}(h8Allow either hunting-and-pecking loop or hash-to-elementh]h8Allow either hunting-and-pecking loop or hash-to-element}(hjshhhNhNubah}(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&]uh1jIhjsubeh}(h]h ]h"]h$]h&]uh1j)hjshMhjAsubeh}(h]h ]h"]h$]h&]uh1j$hj=subah}(h]h ]h"]h$]h&]uh1j;sh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jscfg80211_beacon_data (C struct)c.cfg80211_beacon_datahNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hcfg80211_beacon_datah]j)}(hstruct cfg80211_beacon_datah](j)}(hjh]hstruct}(hj,thhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(thhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hj:thhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(thhhj9thMubj)}(hcfg80211_beacon_datah]j)}(hj&th]hcfg80211_beacon_data}(hjLthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHtubah}(h]h ](jjeh"]h$]h&]jjuh1jhj(thhhj9thMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj$thhhj9thMubah}(h]jtah ](jjeh"]h$]h&]jj)jhuh1j|hj9thMhj!thhubj)}(hhh]h)}(h beacon datah]h beacon data}(hjnthhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMXhjkthhubah}(h]h ]h"]h$]h&]uh1jhj!thhhj9thMubeh}(h]h ](j8structeh"]h$]h&]jj8jjtjjtjjjuh1jwhhhjcchNhNubj)}(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}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubh:}(hjthhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\hjtubj: )}(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; };}hjtsbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^hjtubh)}(h **Members**h]j)}(hjth]hMembers}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMuhjtubj%)}(hhh](j*)}(h@``link_id`` the link ID for the AP MLD link sending this beacon h](j0)}(h ``link_id``h]j,)}(hjth]hlink_id}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjtubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMZhjtubjJ)}(hhh]h)}(h3the link ID for the AP MLD link sending this beaconh]h3the link ID for the AP MLD link sending this beacon}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhjthMZhjtubah}(h]h ]h"]h$]h&]uh1jIhjtubeh}(h]h ]h"]h$]h&]uh1j)hjthMZhjtubj*)}(hK``head`` head portion of beacon (before TIM IE) or ``NULL`` if not changed h](j0)}(h``head``h]j,)}(hjuh]hhead}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjuubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\hjuubjJ)}(hhh]h)}(hAhead portion of beacon (before TIM IE) or ``NULL`` if not changedh](h*head portion of beacon (before TIM IE) or }(hj-uhhhNhNubj,)}(h``NULL``h]hNULL}(hj5uhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj-uubh if not changed}(hj-uhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM[hj*uubah}(h]h ]h"]h$]h&]uh1jIhjuubeh}(h]h ]h"]h$]h&]uh1j)hj)uhM\hjtubj*)}(hJ``tail`` tail portion of beacon (after TIM IE) or ``NULL`` if not changed h](j0)}(h``tail``h]j,)}(hj`uh]htail}(hjbuhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj^uubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^hjZuubjJ)}(hhh]h)}(h@tail portion of beacon (after TIM IE) or ``NULL`` if not changedh](h)tail portion of beacon (after TIM IE) or }(hjyuhhhNhNubj,)}(h``NULL``h]hNULL}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjyuubh if not changed}(hjyuhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM]hjvuubah}(h]h ]h"]h$]h&]uh1jIhjZuubeh}(h]h ]h"]h$]h&]uh1j)hjuuhM^hjtubj*)}(hR``beacon_ies`` extra information element(s) to add into Beacon frames or ``NULL`` h](j0)}(h``beacon_ies``h]j,)}(hjuh]h beacon_ies}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjuubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMahjuubjJ)}(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 }(hjuhhhNhNubj,)}(h``NULL``h]hNULL}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjuubeh}(h]h ]h"]h$]h&]uh1hhjuhMahjuubah}(h]h ]h"]h$]h&]uh1jIhjuubeh}(h]h ]h"]h$]h&]uh1j)hjuhMahjtubj*)}(h]``proberesp_ies`` extra information element(s) to add into Probe Response frames or ``NULL`` h](j0)}(h``proberesp_ies``h]j,)}(hjuh]h proberesp_ies}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjuubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMdhjuubjJ)}(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 }(hj vhhhNhNubj,)}(h``NULL``h]hNULL}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj vubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMchj vubah}(h]h ]h"]h$]h&]uh1jIhjuubeh}(h]h ]h"]h$]h&]uh1j)hjvhMdhjtubj*)}(hg``assocresp_ies`` extra information element(s) to add into (Re)Association Response frames or ``NULL`` h](j0)}(h``assocresp_ies``h]j,)}(hj;vh]h assocresp_ies}(hj=vhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj9vubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMghj5vubjJ)}(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 }(hjTvhhhNhNubj,)}(h``NULL``h]hNULL}(hj\vhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjTvubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMfhjQvubah}(h]h ]h"]h$]h&]uh1jIhj5vubeh}(h]h ]h"]h$]h&]uh1j)hjPvhMghjtubj*)}(h6``probe_resp`` probe response template (AP mode only) h](j0)}(h``probe_resp``h]j,)}(hjvh]h probe_resp}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjvubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMjhj}vubjJ)}(hhh]h)}(h&probe response template (AP mode only)h]h&probe response template (AP mode only)}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhMjhjvubah}(h]h ]h"]h$]h&]uh1jIhj}vubeh}(h]h ]h"]h$]h&]uh1j)hjvhMjhjtubj*)}(ha``lci`` Measurement Report element content, starting with Measurement Token (measurement type 8) h](j0)}(h``lci``h]j,)}(hjvh]hlci}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjvubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMphjvubjJ)}(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)}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMohjvubah}(h]h ]h"]h$]h&]uh1jIhjvubeh}(h]h ]h"]h$]h&]uh1j)hjvhMphjtubj*)}(hg``civicloc`` Measurement Report element content, starting with Measurement Token (measurement type 11) h](j0)}(h ``civicloc``h]j,)}(hjvh]hcivicloc}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjvubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMrhjvubjJ)}(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)}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMqhj wubah}(h]h ]h"]h$]h&]uh1jIhjvubeh}(h]h ]h"]h$]h&]uh1j)hj whMrhjtubj*)}(h'``mbssid_ies`` multiple BSSID elements h](j0)}(h``mbssid_ies``h]j,)}(hj0wh]h mbssid_ies}(hj2whhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj.wubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMkhj*wubjJ)}(hhh]h)}(hmultiple BSSID elementsh]hmultiple BSSID elements}(hjIwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEwhMkhjFwubah}(h]h ]h"]h$]h&]uh1jIhj*wubeh}(h]h ]h"]h$]h&]uh1j)hjEwhMkhjtubj*)}(h-``rnr_ies`` reduced neighbor report elements h](j0)}(h ``rnr_ies``h]j,)}(hjiwh]hrnr_ies}(hjkwhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjgwubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMlhjcwubjJ)}(hhh]h)}(h reduced neighbor report elementsh]h reduced neighbor report elements}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~whMlhjwubah}(h]h ]h"]h$]h&]uh1jIhjcwubeh}(h]h ]h"]h$]h&]uh1j)hj~whMlhjtubj*)}(h``ftm_responder`` enable FTM responder functionality; -1 for no change (which also implies no change in LCI/civic location data) h](j0)}(h``ftm_responder``h]j,)}(hjwh]h ftm_responder}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjwubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMnhjwubjJ)}(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)}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMmhjwubah}(h]h ]h"]h$]h&]uh1jIhjwubeh}(h]h ]h"]h$]h&]uh1j)hjwhMnhjtubj*)}(h ``head_len`` length of **head** h](j0)}(h ``head_len``h]j,)}(hjwh]hhead_len}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjwubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM_hjwubjJ)}(hhh]h)}(hlength of **head**h](h length of }(hjwhhhNhNubj)}(h**head**h]hhead}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubeh}(h]h ]h"]h$]h&]uh1hhjwhM_hjwubah}(h]h ]h"]h$]h&]uh1jIhjwubeh}(h]h ]h"]h$]h&]uh1j)hjwhM_hjtubj*)}(h ``tail_len`` length of **tail** h](j0)}(h ``tail_len``h]j,)}(hj#xh]htail_len}(hj%xhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj!xubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM`hjxubjJ)}(hhh]h)}(hlength of **tail**h](h length of }(hj` ``he_obss_pd`` OBSS Packet Detection settings ``fils_discovery`` FILS discovery transmission parameters ``unsol_bcast_probe_resp`` Unsolicited broadcast probe response parameters ``mbssid_config`` AP settings for multiple bssid ``s1g_long_beacon_period`` S1G long beacon period ``s1g_short_beacon`` S1G short beacon datah](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubh:}(hjzhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzubj: )}(hXstruct cfg80211_ap_settings { struct cfg80211_chan_def chandef; struct cfg80211_beacon_data beacon; int beacon_interval, dtim_period; const u8 *ssid; size_t ssid_len; enum nl80211_hidden_ssid hidden_ssid; struct cfg80211_crypto_settings crypto; bool privacy; enum nl80211_auth_type auth_type; int inactivity_timeout; u8 p2p_ctwindow; bool p2p_opp_ps; const struct cfg80211_acl_data *acl; bool pbss; struct cfg80211_bitrate_mask beacon_rate; const struct ieee80211_ht_cap *ht_cap; const struct ieee80211_vht_cap *vht_cap; const struct ieee80211_he_cap_elem *he_cap; const struct ieee80211_he_operation *he_oper; const struct ieee80211_eht_cap_elem *eht_cap; const struct ieee80211_eht_operation *eht_oper; const struct ieee80211_uhr_operation *uhr_oper; bool ht_required, vht_required, he_required, sae_h2e_required; bool twt_responder; u32 flags; struct ieee80211_he_obss_pd he_obss_pd; struct cfg80211_fils_discovery fils_discovery; struct cfg80211_unsol_bcast_probe_resp unsol_bcast_probe_resp; struct cfg80211_mbssid_config mbssid_config; u8 s1g_long_beacon_period; struct cfg80211_s1g_short_beacon s1g_short_beacon; };h]hXstruct cfg80211_ap_settings { struct cfg80211_chan_def chandef; struct cfg80211_beacon_data beacon; int beacon_interval, dtim_period; const u8 *ssid; size_t ssid_len; enum nl80211_hidden_ssid hidden_ssid; struct cfg80211_crypto_settings crypto; bool privacy; enum nl80211_auth_type auth_type; int inactivity_timeout; u8 p2p_ctwindow; bool p2p_opp_ps; const struct cfg80211_acl_data *acl; bool pbss; struct cfg80211_bitrate_mask beacon_rate; const struct ieee80211_ht_cap *ht_cap; const struct ieee80211_vht_cap *vht_cap; const struct ieee80211_he_cap_elem *he_cap; const struct ieee80211_he_operation *he_oper; const struct ieee80211_eht_cap_elem *eht_cap; const struct ieee80211_eht_operation *eht_oper; const struct ieee80211_uhr_operation *uhr_oper; bool ht_required, vht_required, he_required, sae_h2e_required; bool twt_responder; u32 flags; struct ieee80211_he_obss_pd he_obss_pd; struct cfg80211_fils_discovery fils_discovery; struct cfg80211_unsol_bcast_probe_resp unsol_bcast_probe_resp; struct cfg80211_mbssid_config mbssid_config; u8 s1g_long_beacon_period; struct cfg80211_s1g_short_beacon s1g_short_beacon; };}hjzsbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzubh)}(h **Members**h]j)}(hjzh]hMembers}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjzubj%)}(hhh](j*)}(h'``chandef`` defines the channel to use h](j0)}(h ``chandef``h]j,)}(hj{h]hchandef}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj{ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj {ubjJ)}(hhh]h)}(hdefines the channel to useh]hdefines the channel to use}(hj,{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj({hMhj){ubah}(h]h ]h"]h$]h&]uh1jIhj {ubeh}(h]h ]h"]h$]h&]uh1j)hj({hMhj {ubj*)}(h``beacon`` beacon data h](j0)}(h ``beacon``h]j,)}(hjL{h]hbeacon}(hjN{hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjJ{ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjF{ubjJ)}(hhh]h)}(h beacon datah]h beacon data}(hje{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhja{hMhjb{ubah}(h]h ]h"]h$]h&]uh1jIhjF{ubeh}(h]h ]h"]h$]h&]uh1j)hja{hMhj {ubj*)}(h$``beacon_interval`` beacon interval h](j0)}(h``beacon_interval``h]j,)}(hj{h]hbeacon_interval}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj{ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{ubjJ)}(hhh]h)}(hbeacon intervalh]hbeacon interval}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hMhj{ubah}(h]h ]h"]h$]h&]uh1jIhj{ubeh}(h]h ]h"]h$]h&]uh1j)hj{hMhj {ubj*)}(h``dtim_period`` DTIM period h](j0)}(h``dtim_period``h]j,)}(hj{h]h dtim_period}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj{ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{ubjJ)}(hhh]h)}(h DTIM periodh]h DTIM period}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hMhj{ubah}(h]h ]h"]h$]h&]uh1jIhj{ubeh}(h]h ]h"]h$]h&]uh1j)hj{hMhj {ubj*)}(h\``ssid`` SSID to be used in the BSS (note: may be ``NULL`` if not provided from user space) h](j0)}(h``ssid``h]j,)}(hj{h]hssid}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj{ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{ubjJ)}(hhh]h)}(hRSSID to be used in the BSS (note: may be ``NULL`` if not provided from user space)h](h)SSID to be used in the BSS (note: may be }(hj|hhhNhNubj,)}(h``NULL``h]hNULL}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj|ubh! if not provided from user space)}(hj|hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj |ubah}(h]h ]h"]h$]h&]uh1jIhj{ubeh}(h]h ]h"]h$]h&]uh1j)hj |hMhj {ubj*)}(h ``ssid_len`` length of **ssid** h](j0)}(h ``ssid_len``h]j,)}(hjC|h]hssid_len}(hjE|hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjA|ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj=|ubjJ)}(hhh]h)}(hlength of **ssid**h](h length of }(hj\|hhhNhNubj)}(h**ssid**h]hssid}(hjd|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\|ubeh}(h]h ]h"]h$]h&]uh1hhjX|hMhjY|ubah}(h]h ]h"]h$]h&]uh1jIhj=|ubeh}(h]h ]h"]h$]h&]uh1j)hjX|hMhj {ubj*)}(hI``hidden_ssid`` whether to hide the SSID in Beacon/Probe Response frames h](j0)}(h``hidden_ssid``h]j,)}(hj|h]h hidden_ssid}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj|ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj|ubjJ)}(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&]uh1jIhj|ubeh}(h]h ]h"]h$]h&]uh1j)hj|hMhj {ubj*)}(h``crypto`` crypto settings h](j0)}(h ``crypto``h]j,)}(hj|h]hcrypto}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj|ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj|ubjJ)}(hhh]h)}(hcrypto settingsh]hcrypto settings}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMhj|ubah}(h]h ]h"]h$]h&]uh1jIhj|ubeh}(h]h ]h"]h$]h&]uh1j)hj|hMhj {ubj*)}(h!``privacy`` the BSS uses privacy h](j0)}(h ``privacy``h]j,)}(hj|h]hprivacy}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj|ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj|ubjJ)}(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&]uh1jIhj|ubeh}(h]h ]h"]h$]h&]uh1j)hj}hMhj {ubj*)}(h.``auth_type`` Authentication type (algorithm) h](j0)}(h ``auth_type``h]j,)}(hj5}h]h auth_type}(hj7}hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj3}ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj/}ubjJ)}(hhh]h)}(hAuthentication type (algorithm)h]hAuthentication type (algorithm)}(hjN}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJ}hMhjK}ubah}(h]h ]h"]h$]h&]uh1jIhj/}ubeh}(h]h ]h"]h$]h&]uh1j)hjJ}hMhj {ubj*)}(hJ``inactivity_timeout`` time in seconds to determine station's inactivity. h](j0)}(h``inactivity_timeout``h]j,)}(hjn}h]hinactivity_timeout}(hjp}hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjl}ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjh}ubjJ)}(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&]uh1jIhjh}ubeh}(h]h ]h"]h$]h&]uh1j)hj}hMhj {ubj*)}(h``p2p_ctwindow`` P2P CT Window h](j0)}(h``p2p_ctwindow``h]j,)}(hj}h]h p2p_ctwindow}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj}ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj}ubjJ)}(hhh]h)}(h P2P CT Windowh]h P2P CT Window}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}hMhj}ubah}(h]h ]h"]h$]h&]uh1jIhj}ubeh}(h]h ]h"]h$]h&]uh1j)hj}hMhj {ubj*)}(h$``p2p_opp_ps`` P2P opportunistic PS h](j0)}(h``p2p_opp_ps``h]j,)}(hj}h]h p2p_opp_ps}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj}ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj}ubjJ)}(hhh]h)}(hP2P opportunistic PSh]hP2P opportunistic PS}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}hMhj}ubah}(h]h ]h"]h$]h&]uh1jIhj}ubeh}(h]h ]h"]h$]h&]uh1j)hj}hMhj {ubj*)}(he``acl`` ACL configuration used by the drivers which has support for MAC address based access control h](j0)}(h``acl``h]j,)}(hj~h]hacl}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj~ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubjJ)}(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}(hj2~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&]uh1jIhj~ubeh}(h]h ]h"]h$]h&]uh1j)hj.~hMhj {ubj*)}(hJ``pbss`` If set, start as a PCP instead of AP. Relevant for DMG networks. h](j0)}(h``pbss``h]j,)}(hjS~h]hpbss}(hjU~hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjQ~ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjM~ubjJ)}(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.}(hjl~hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhji~ubah}(h]h ]h"]h$]h&]uh1jIhjM~ubeh}(h]h ]h"]h$]h&]uh1j)hjh~hMhj {ubj*)}(h/``beacon_rate`` bitrate to be used for beacons h](j0)}(h``beacon_rate``h]j,)}(hj~h]h beacon_rate}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj~ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubjJ)}(hhh]h)}(hbitrate to be used for beaconsh]hbitrate to be used for beacons}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~hMhj~ubah}(h]h ]h"]h$]h&]uh1jIhj~ubeh}(h]h ]h"]h$]h&]uh1j)hj~hMhj {ubj*)}(h=``ht_cap`` HT capabilities (or ``NULL`` if HT isn't enabled) h](j0)}(h ``ht_cap``h]j,)}(hj~h]hht_cap}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj~ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubjJ)}(hhh]h)}(h1HT capabilities (or ``NULL`` if HT isn't enabled)h](hHT capabilities (or }(hj~hhhNhNubj,)}(h``NULL``h]hNULL}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj~ubh if HT isn’t enabled)}(hj~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj~hMhj~ubah}(h]h ]h"]h$]h&]uh1jIhj~ubeh}(h]h ]h"]h$]h&]uh1j)hj~hMhj {ubj*)}(h@``vht_cap`` VHT capabilities (or ``NULL`` if VHT isn't enabled) h](j0)}(h ``vht_cap``h]j,)}(hjh]hvht_cap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubjJ)}(hhh]h)}(h3VHT capabilities (or ``NULL`` if VHT isn't enabled)h](hVHT capabilities (or }(hj*hhhNhNubj,)}(h``NULL``h]hNULL}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj*ubh if VHT isn’t enabled)}(hj*hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj&hMhj'ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj&hMhj {ubj*)}(h=``he_cap`` HE capabilities (or ``NULL`` if HE isn't enabled) h](j0)}(h ``he_cap``h]j,)}(hj\h]hhe_cap}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjZubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjVubjJ)}(hhh]h)}(h1HE capabilities (or ``NULL`` if HE isn't enabled)h](hHE capabilities (or }(hjuhhhNhNubj,)}(h``NULL``h]hNULL}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjuubh if HE isn’t enabled)}(hjuhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjqhMhjrubah}(h]h ]h"]h$]h&]uh1jIhjVubeh}(h]h ]h"]h$]h&]uh1j)hjqhMhj {ubj*)}(h>``he_oper`` HE operation IE (or ``NULL`` if HE isn't enabled) h](j0)}(h ``he_oper``h]j,)}(hjh]hhe_oper}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h1HE operation IE (or ``NULL`` if HE isn't enabled)h](hHE operation IE (or }(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh if HE isn’t enabled)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj {ubj*)}(h@``eht_cap`` EHT capabilities (or ``NULL`` if EHT isn't enabled) h](j0)}(h ``eht_cap``h]j,)}(hjh]heht_cap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h3EHT capabilities (or ``NULL`` if EHT isn't enabled)h](hEHT capabilities (or }(hj hhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubh if EHT isn’t enabled)}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj {ubj*)}(hA``eht_oper`` EHT operation IE (or ``NULL`` if EHT isn't enabled) h](j0)}(h ``eht_oper``h]j,)}(hj=h]heht_oper}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj;ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj7ubjJ)}(hhh]h)}(h3EHT operation IE (or ``NULL`` if EHT isn't enabled)h](hEHT operation IE (or }(hjVhhhNhNubj,)}(h``NULL``h]hNULL}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjVubh if EHT isn’t enabled)}(hjVhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjRhMhjSubah}(h]h ]h"]h$]h&]uh1jIhj7ubeh}(h]h ]h"]h$]h&]uh1j)hjRhMhj {ubj*)}(h>``uhr_oper`` UHR operation (or ``NULL`` if UHR isn't enabled) h](j0)}(h ``uhr_oper``h]j,)}(hjh]huhr_oper}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h0UHR operation (or ``NULL`` if UHR isn't enabled)h](hUHR operation (or }(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh if UHR isn’t enabled)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj {ubj*)}(h)``ht_required`` stations must support HT h](j0)}(h``ht_required``h]j,)}(hjӀh]h ht_required}(hjՀhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjрubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj̀ubjJ)}(hhh]h)}(hstations must support HTh]hstations must support HT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhj̀ubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj {ubj*)}(h+``vht_required`` stations must support VHT h](j0)}(h``vht_required``h]j,)}(hj h]h vht_required}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hstations must support VHTh]hstations must support VHT}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hMhj"ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj!hMhj {ubj*)}(h)``he_required`` stations must support HE h](j0)}(h``he_required``h]j,)}(hjEh]h he_required}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjCubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj?ubjJ)}(hhh]h)}(hstations must support HEh]hstations must support HE}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhj[ubah}(h]h ]h"]h$]h&]uh1jIhj?ubeh}(h]h ]h"]h$]h&]uh1j)hjZhMhj {ubj*)}(hG``sae_h2e_required`` stations must support direct H2E technique in SAE h](j0)}(h``sae_h2e_required``h]j,)}(hj~h]hsae_h2e_required}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj|ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjxubjJ)}(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&]uh1jIhjxubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj {ubj*)}(h*``twt_responder`` Enable Target Wait Time h](j0)}(h``twt_responder``h]j,)}(hjh]h twt_responder}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hEnable Target Wait Timeh]hEnable Target Wait Time}(hjЁhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj́hMhj́ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj́hMhj {ubj*)}(hd``flags`` flags, as defined in :c:type:`enum nl80211_ap_settings_flags ` h](j0)}(h ``flags``h]j,)}(hjh]hflags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hYflags, as defined in :c:type:`enum nl80211_ap_settings_flags `h](hflags, as defined in }(hj hhhNhNubh)}(hD:c:type:`enum nl80211_ap_settings_flags `h]j,)}(hjh]henum nl80211_ap_settings_flags}(hjhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_ap_settings_flagsuh1hhjhMhj ubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj {ubj*)}(h.``he_obss_pd`` OBSS Packet Detection settings h](j0)}(h``he_obss_pd``h]j,)}(hjHh]h he_obss_pd}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjFubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjBubjJ)}(hhh]h)}(hOBSS Packet Detection settingsh]hOBSS Packet Detection settings}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hMhj^ubah}(h]h ]h"]h$]h&]uh1jIhjBubeh}(h]h ]h"]h$]h&]uh1j)hj]hMhj {ubj*)}(h:``fils_discovery`` FILS discovery transmission parameters h](j0)}(h``fils_discovery``h]j,)}(hjh]hfils_discovery}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{ubjJ)}(hhh]h)}(h&FILS discovery transmission parametersh]h&FILS discovery transmission parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhj{ubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj {ubj*)}(hK``unsol_bcast_probe_resp`` Unsolicited broadcast probe response parameters h](j0)}(h``unsol_bcast_probe_resp``h]j,)}(hjh]hunsol_bcast_probe_resp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h/Unsolicited broadcast probe response parametersh]h/Unsolicited broadcast probe response parameters}(hjӂhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjςhMhjЂubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjςhMhj {ubj*)}(h1``mbssid_config`` AP settings for multiple bssid h](j0)}(h``mbssid_config``h]j,)}(hjh]h mbssid_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hAP settings for multiple bssidh]hAP settings for multiple bssid}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj {ubj*)}(h2``s1g_long_beacon_period`` S1G long beacon period h](j0)}(h``s1g_long_beacon_period``h]j,)}(hj,h]hs1g_long_beacon_period}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj*ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj&ubjJ)}(hhh]h)}(hS1G long beacon periodh]hS1G long beacon period}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhMhjBubah}(h]h ]h"]h$]h&]uh1jIhj&ubeh}(h]h ]h"]h$]h&]uh1j)hjAhMhj {ubj*)}(h*``s1g_short_beacon`` S1G short beacon datah](j0)}(h``s1g_short_beacon``h]j,)}(hjeh]hs1g_short_beacon}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjcubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj_ubjJ)}(hhh]h)}(hS1G short beacon datah]hS1G short beacon data}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{ubah}(h]h ]h"]h$]h&]uh1jIhj_ubeh}(h]h ]h"]h$]h&]uh1j)hjzhMhj {ubeh}(h]h ]h"]h$]h&]uh1j$hjzubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubh)}(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.hhMhjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsstation_parameters (C struct)c.station_parametershNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hstation_parametersh]j)}(hstruct station_parametersh](j)}(hjh]hstruct}(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)}(hstation_parametersh]j)}(hjh]hstation_parameters}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjރhhhjhMubah}(h]jكah ](jjeh"]h$]h&]jj)jhuh1j|hjhMhjۃhhubj)}(hhh]h)}(hstation parametersh]hstation parameters}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj%hhubah}(h]h ]h"]h$]h&]uh1jhjۃhhhjhMubeh}(h]h ](j8structeh"]h$]h&]jj8jj@jj@jjjuh1jwhhhjcchNhNubj)}(hXv **Definition**:: struct station_parameters { struct net_device *vlan; u32 sta_flags_mask, sta_flags_set; u32 sta_modify_mask; int listen_interval; u16 aid; u16 vlan_id; u16 peer_aid; u8 plink_action; u8 plink_state; u8 uapsd_queues; u8 max_sp; enum nl80211_mesh_power_mode local_pm; u16 capability; const u8 *ext_capab; u8 ext_capab_len; const u8 *supported_channels; u8 supported_channels_len; const u8 *supported_oper_classes; u8 supported_oper_classes_len; int support_p2p_ps; u16 airtime_weight; bool eml_cap_present; u16 eml_cap; struct link_station_parameters link_sta_params; bool epp_peer; const u8 *nmi_mac; }; **Members** ``vlan`` vlan interface station should belong to ``sta_flags_mask`` station flags that changed (bitmask of BIT(``NL80211_STA_FLAG_``...)) ``sta_flags_set`` station flags values (bitmask of BIT(``NL80211_STA_FLAG_``...)) ``sta_modify_mask`` bitmap indicating which parameters changed (for those that don't have a natural "no change" value), see :c:type:`enum station_parameters_apply_mask ` ``listen_interval`` listen interval or -1 for no change ``aid`` AID or zero for no change ``vlan_id`` VLAN ID for station (if nonzero) ``peer_aid`` mesh peer AID or zero for no change ``plink_action`` plink action to take ``plink_state`` set the peer link state for a station ``uapsd_queues`` bitmap of queues configured for uapsd. same format as the AC bitmap in the QoS info field ``max_sp`` max Service Period. same format as the MAX_SP in the QoS info field (but already shifted down) ``local_pm`` local link-specific mesh power save mode (no change when set to unknown) ``capability`` station capability ``ext_capab`` extended capabilities of the station ``ext_capab_len`` number of extended capabilities ``supported_channels`` supported channels in IEEE 802.11 format ``supported_channels_len`` number of supported channels ``supported_oper_classes`` supported oper classes in IEEE 802.11 format ``supported_oper_classes_len`` number of supported operating classes ``support_p2p_ps`` information if station supports P2P PS mechanism ``airtime_weight`` airtime scheduler weight for this station ``eml_cap_present`` Specifies if EML capabilities field (**eml_cap**) is present/updated ``eml_cap`` EML capabilities of this station ``link_sta_params`` link related params. ``epp_peer`` EPP peer indication ``nmi_mac`` MAC address of the NMI station of the NAN peerh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubh:}(hjHhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjDubj: )}(hXstruct station_parameters { struct net_device *vlan; u32 sta_flags_mask, sta_flags_set; u32 sta_modify_mask; int listen_interval; u16 aid; u16 vlan_id; u16 peer_aid; u8 plink_action; u8 plink_state; u8 uapsd_queues; u8 max_sp; enum nl80211_mesh_power_mode local_pm; u16 capability; const u8 *ext_capab; u8 ext_capab_len; const u8 *supported_channels; u8 supported_channels_len; const u8 *supported_oper_classes; u8 supported_oper_classes_len; int support_p2p_ps; u16 airtime_weight; bool eml_cap_present; u16 eml_cap; struct link_station_parameters link_sta_params; bool epp_peer; const u8 *nmi_mac; };h]hXstruct station_parameters { struct net_device *vlan; u32 sta_flags_mask, sta_flags_set; u32 sta_modify_mask; int listen_interval; u16 aid; u16 vlan_id; u16 peer_aid; u8 plink_action; u8 plink_state; u8 uapsd_queues; u8 max_sp; enum nl80211_mesh_power_mode local_pm; u16 capability; const u8 *ext_capab; u8 ext_capab_len; const u8 *supported_channels; u8 supported_channels_len; const u8 *supported_oper_classes; u8 supported_oper_classes_len; int support_p2p_ps; u16 airtime_weight; bool eml_cap_present; u16 eml_cap; struct link_station_parameters link_sta_params; bool epp_peer; const u8 *nmi_mac; };}hjesbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjDubh)}(h **Members**h]j)}(hjvh]hMembers}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM'hjDubj%)}(hhh](j*)}(h1``vlan`` vlan interface station should belong to h](j0)}(h``vlan``h]j,)}(hjh]hvlan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h'vlan interface station should belong toh]h'vlan interface station should belong to}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(hY``sta_flags_mask`` station flags that changed (bitmask of BIT(``NL80211_STA_FLAG_``...)) h](j0)}(h``sta_flags_mask``h]j,-)}(hj΄h]hsta_flags_mask}(hjЄhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj̄ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjȄubjJ)}(hhh]h)}(hEstation flags that changed (bitmask of BIT(``NL80211_STA_FLAG_``...))h](h+station flags that changed (bitmask of BIT(}(hjhhhNhNubj,)}(h``NL80211_STA_FLAG_``h]hNL80211_STA_FLAG_}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh...))}(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&]uh1jIhjȄubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(hR``sta_flags_set`` station flags values (bitmask of BIT(``NL80211_STA_FLAG_``...)) h](j0)}(h``sta_flags_set``h]j,)}(hjh]h sta_flags_set}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h?station flags values (bitmask of BIT(``NL80211_STA_FLAG_``...))h](h%station flags values (bitmask of BIT(}(hj3hhhNhNubj,)}(h``NL80211_STA_FLAG_``h]hNL80211_STA_FLAG_}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj3ubh...))}(hj3hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj0ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj/hM hjubj*)}(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](j0)}(h``sta_modify_mask``h]j,)}(hjfh]hsta_modify_mask}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjdubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj`ubjJ)}(hhh]h)}(hbitmap indicating which parameters changed (for those that don't have a natural "no change" value), see :c:type:`enum station_parameters_apply_mask `h](hnbitmap indicating which parameters changed (for those that don’t have a natural “no change” value), see }(hjhhhNhNubh)}(hL:c:type:`enum station_parameters_apply_mask `h]j,)}(hjh]h"enum station_parameters_apply_mask}(hjhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJstation_parameters_apply_maskuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhj|ubah}(h]h ]h"]h$]h&]uh1jIhj`ubeh}(h]h ]h"]h$]h&]uh1j)hj{hMhjubj*)}(h8``listen_interval`` listen interval or -1 for no change h](j0)}(h``listen_interval``h]j,)}(hjh]hlisten_interval}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h#listen interval or -1 for no changeh]h#listen interval or -1 for no change}(hj؅hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjԅhMhjՅubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjԅhMhjubj*)}(h"``aid`` AID or zero for no change h](j0)}(h``aid``h]j,)}(hjh]haid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hAID or zero for no changeh]hAID or zero for no change}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hMhjubj*)}(h-``vlan_id`` VLAN ID for station (if nonzero) h](j0)}(h ``vlan_id``h]j,)}(hj1h]hvlan_id}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj/ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj+ubjJ)}(hhh]h)}(h VLAN ID for station (if nonzero)h]h VLAN ID for station (if nonzero)}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhMhjGubah}(h]h ]h"]h$]h&]uh1jIhj+ubeh}(h]h ]h"]h$]h&]uh1j)hjFhMhjubj*)}(h1``peer_aid`` mesh peer AID or zero for no change h](j0)}(h ``peer_aid``h]j,)}(hjjh]hpeer_aid}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjhubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjdubjJ)}(hhh]h)}(h#mesh peer AID or zero for no changeh]h#mesh peer AID or zero for no change}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjdubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjubj*)}(h&``plink_action`` plink action to take h](j0)}(h``plink_action``h]j,)}(hjh]h plink_action}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hplink action to takeh]hplink action to take}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjubj*)}(h6``plink_state`` set the peer link state for a station h](j0)}(h``plink_state``h]j,)}(hj܆h]h plink_state}(hjކhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjچubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjֆubjJ)}(hhh]h)}(h%set the peer link state for a stationh]h%set the peer link state for a station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjֆubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjubj*)}(hk``uapsd_queues`` bitmap of queues configured for uapsd. same format as the AC bitmap in the QoS info field h](j0)}(h``uapsd_queues``h]j,)}(hjh]h uapsd_queues}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj*hMhjubj*)}(hj``max_sp`` max Service Period. same format as the MAX_SP in the QoS info field (but already shifted down) h](j0)}(h ``max_sp``h]j,)}(hjOh]hmax_sp}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjMubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjIubjJ)}(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)}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjeubah}(h]h ]h"]h$]h&]uh1jIhjIubeh}(h]h ]h"]h$]h&]uh1j)hjdhMhjubj*)}(hV``local_pm`` local link-specific mesh power save mode (no change when set to unknown) h](j0)}(h ``local_pm``h]j,)}(hjh]hlocal_pm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjubj*)}(h"``capability`` station capability h](j0)}(h``capability``h]j,)}(hjÇh]h capability}(hjŇhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hstation capabilityh]hstation capability}(hj܇hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj؇hMhjهubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj؇hMhjubj*)}(h3``ext_capab`` extended capabilities of the station h](j0)}(h ``ext_capab``h]j,)}(hjh]h ext_capab}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjubj*)}(h2``ext_capab_len`` number of extended capabilities h](j0)}(h``ext_capab_len``h]j,)}(hj5h]h ext_capab_len}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj3ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj/ubjJ)}(hhh]h)}(hnumber of extended capabilitiesh]hnumber of extended capabilities}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJhMhjKubah}(h]h ]h"]h$]h&]uh1jIhj/ubeh}(h]h ]h"]h$]h&]uh1j)hjJhMhjubj*)}(h@``supported_channels`` supported channels in IEEE 802.11 format h](j0)}(h``supported_channels``h]j,)}(hjnh]hsupported_channels}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjlubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhubjJ)}(hhh]h)}(h(supported channels in IEEE 802.11 formath]h(supported channels in IEEE 802.11 format}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjhubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h8``supported_channels_len`` number of supported channels h](j0)}(h``supported_channels_len``h]j,)}(hjh]hsupported_channels_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM!hjubjJ)}(hhh]h)}(hnumber of supported channelsh]hnumber of supported channels}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM!hjubj*)}(hH``supported_oper_classes`` supported oper classes in IEEE 802.11 format h](j0)}(h``supported_oper_classes``h]j,)}(hjh]hsupported_oper_classes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjވubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjڈubjJ)}(hhh]h)}(h,supported oper classes in IEEE 802.11 formath]h,supported oper classes in IEEE 802.11 format}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1jIhjڈubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjubj*)}(hE``supported_oper_classes_len`` number of supported operating classes h](j0)}(h``supported_oper_classes_len``h]j,)}(hjh]hsupported_oper_classes_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hjubjJ)}(hhh]h)}(h%number of supported operating classesh]h%number of supported operating classes}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.hM#hj/ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj.hM#hjubj*)}(hD``support_p2p_ps`` information if station supports P2P PS mechanism h](j0)}(h``support_p2p_ps``h]j,)}(hjRh]hsupport_p2p_ps}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjPubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hjLubjJ)}(hhh]h)}(h0information if station supports P2P PS mechanismh]h0information if station supports P2P PS mechanism}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghM$hjhubah}(h]h ]h"]h$]h&]uh1jIhjLubeh}(h]h ]h"]h$]h&]uh1j)hjghM$hjubj*)}(h=``airtime_weight`` airtime scheduler weight for this station h](j0)}(h``airtime_weight``h]j,)}(hjh]hairtime_weight}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM%hjubjJ)}(hhh]h)}(h)airtime scheduler weight for this stationh]h)airtime scheduler weight for this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM%hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM%hjubj*)}(hY``eml_cap_present`` Specifies if EML capabilities field (**eml_cap**) is present/updated h](j0)}(h``eml_cap_present``h]j,)}(hjĉh]heml_cap_present}(hjƉhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj‰ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM'hjubjJ)}(hhh]h)}(hDSpecifies if EML capabilities field (**eml_cap**) is present/updatedh](h%Specifies if EML capabilities field (}(hj݉hhhNhNubj)}(h **eml_cap**h]heml_cap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj݉ubh) is present/updated}(hj݉hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM&hjډubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjىhM'hjubj*)}(h-``eml_cap`` EML capabilities of this station h](j0)}(h ``eml_cap``h]j,)}(hjh]heml_cap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM(hj ubjJ)}(hhh]h)}(h EML capabilities of this stationh]h EML capabilities of this station}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hM(hj&ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj%hM(hjubj*)}(h)``link_sta_params`` link related params. h](j0)}(h``link_sta_params``h]j,)}(hjIh]hlink_sta_params}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjGubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM)hjCubjJ)}(hhh]h)}(hlink related params.h]hlink related params.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hM)hj_ubah}(h]h ]h"]h$]h&]uh1jIhjCubeh}(h]h ]h"]h$]h&]uh1j)hj^hM)hjubj*)}(h!``epp_peer`` EPP peer indication h](j0)}(h ``epp_peer``h]j,)}(hjh]hepp_peer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM*hj|ubjJ)}(hhh]h)}(hEPP peer indicationh]hEPP peer indication}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM*hjubah}(h]h ]h"]h$]h&]uh1jIhj|ubeh}(h]h ]h"]h$]h&]uh1j)hjhM*hjubj*)}(h:``nmi_mac`` MAC address of the NMI station of the NAN peerh](j0)}(h ``nmi_mac``h]j,)}(hjh]hnmi_mac}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM*hjubjJ)}(hhh]h)}(h.MAC address of the NMI station of the NAN peerh]h.MAC address of the NMI station of the NAN peer}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjЊhM*hjubeh}(h]h ]h"]h$]h&]uh1j$hjDubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM.hjcchhubh)}(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.hhMhjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsrate_info_flags (C enum)c.rate_info_flagshNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hrate_info_flagsh]j)}(henum rate_info_flagsh](j)}(hjh]henum}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8hhhjIhM ubj)}(hrate_info_flagsh]j)}(hj6h]hrate_info_flags}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubah}(h]h ](jjeh"]h$]h&]jjuh1jhj8hhhjIhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj4hhhjIhM ubah}(h]j/ah ](jjeh"]h$]h&]jj)jhuh1j|hjIhM hj1hhubj)}(hhh]h)}(hbitrate info flagsh]hbitrate info flags}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj{hhubah}(h]h ]h"]h$]h&]uh1jhj1hhhjIhM ubeh}(h]h ](j8enumeh"]h$]h&]jj8jjjjjjjuh1jwhhhjcchNhNubj)}(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 MCS ``RATE_INFO_FLAGS_UHR_MCS`` UHR MCS information ``RATE_INFO_FLAGS_UHR_ELR_MCS`` UHR ELR MCS was used (set together with **RATE_INFO_FLAGS_UHR_MCS**) ``RATE_INFO_FLAGS_UHR_IM`` UHR Interference Mitigation was usedh](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj%)}(hhh](j*)}(h5``RATE_INFO_FLAGS_MCS`` mcs field filled with HT MCS h](j0)}(h``RATE_INFO_FLAGS_MCS``h]j,)}(hjh]hRATE_INFO_FLAGS_MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hmcs field filled with HT MCSh]hmcs field filled with HT MCS}(hj؋hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjԋhMhjՋubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjԋhMhjubj*)}(h:``RATE_INFO_FLAGS_VHT_MCS`` mcs field filled with VHT MCS h](j0)}(h``RATE_INFO_FLAGS_VHT_MCS``h]j,)}(hjh]hRATE_INFO_FLAGS_VHT_MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hmcs field filled with VHT MCSh]hmcs field filled with VHT MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hMhjubj*)}(h2``RATE_INFO_FLAGS_SHORT_GI`` 400ns guard interval h](j0)}(h``RATE_INFO_FLAGS_SHORT_GI``h]j,)}(hj1h]hRATE_INFO_FLAGS_SHORT_GI}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj/ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj+ubjJ)}(hhh]h)}(h400ns guard intervalh]h400ns guard interval}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhMhjGubah}(h]h ]h"]h$]h&]uh1jIhj+ubeh}(h]h ]h"]h$]h&]uh1j)hjFhMhjubj*)}(h"``RATE_INFO_FLAGS_DMG`` 60GHz MCS h](j0)}(h``RATE_INFO_FLAGS_DMG``h]j,)}(hjjh]hRATE_INFO_FLAGS_DMG}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjhubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjdubjJ)}(hhh]h)}(h 60GHz MCSh]h 60GHz MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjdubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjubj*)}(h.``RATE_INFO_FLAGS_HE_MCS`` HE MCS information h](j0)}(h``RATE_INFO_FLAGS_HE_MCS``h]j,)}(hjh]hRATE_INFO_FLAGS_HE_MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hHE MCS informationh]hHE MCS information}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjubj*)}(h0``RATE_INFO_FLAGS_EDMG`` 60GHz MCS in EDMG mode h](j0)}(h``RATE_INFO_FLAGS_EDMG``h]j,)}(hj܌h]hRATE_INFO_FLAGS_EDMG}(hjތhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjڌubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj֌ubjJ)}(hhh]h)}(h60GHz MCS in EDMG modeh]h60GHz MCS in EDMG mode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhj֌ubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjubj*)}(h:``RATE_INFO_FLAGS_EXTENDED_SC_DMG`` 60GHz extended SC MCS h](j0)}(h#``RATE_INFO_FLAGS_EXTENDED_SC_DMG``h]j,)}(hjh]hRATE_INFO_FLAGS_EXTENDED_SC_DMG}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h60GHz extended SC MCSh]h60GHz extended SC MCS}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hMhj+ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj*hMhjubj*)}(h0``RATE_INFO_FLAGS_EHT_MCS`` EHT MCS information h](j0)}(h``RATE_INFO_FLAGS_EHT_MCS``h]j,)}(hjNh]hRATE_INFO_FLAGS_EHT_MCS}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjLubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjHubjJ)}(hhh]h)}(hEHT MCS informationh]hEHT MCS information}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchMhjdubah}(h]h ]h"]h$]h&]uh1jIhjHubeh}(h]h ]h"]h$]h&]uh1j)hjchMhjubj*)}(h:``RATE_INFO_FLAGS_S1G_MCS`` MCS field filled with S1G MCS h](j0)}(h``RATE_INFO_FLAGS_S1G_MCS``h]j,)}(hjh]hRATE_INFO_FLAGS_S1G_MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hMCS field filled with S1G MCSh]hMCS field filled with S1G MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjubj*)}(h0``RATE_INFO_FLAGS_UHR_MCS`` UHR MCS information h](j0)}(h``RATE_INFO_FLAGS_UHR_MCS``h]j,)}(hjh]hRATE_INFO_FLAGS_UHR_MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hUHR MCS informationh]hUHR MCS information}(hjٍhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjՍhMhj֍ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjՍhMhjubj*)}(he``RATE_INFO_FLAGS_UHR_ELR_MCS`` UHR ELR MCS was used (set together with **RATE_INFO_FLAGS_UHR_MCS**) h](j0)}(h``RATE_INFO_FLAGS_UHR_ELR_MCS``h]j,)}(hjh]hRATE_INFO_FLAGS_UHR_ELR_MCS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hDUHR ELR MCS was used (set together with **RATE_INFO_FLAGS_UHR_MCS**)h](h(UHR ELR MCS was used (set together with }(hjhhhNhNubj)}(h**RATE_INFO_FLAGS_UHR_MCS**h]hRATE_INFO_FLAGS_UHR_MCS}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjubj*)}(h?``RATE_INFO_FLAGS_UHR_IM`` UHR Interference Mitigation was usedh](j0)}(h``RATE_INFO_FLAGS_UHR_IM``h]j,)}(hjEh]hRATE_INFO_FLAGS_UHR_IM}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjCubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj?ubjJ)}(hhh]h)}(h$UHR Interference Mitigation was usedh]h$UHR Interference Mitigation was used}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhj[ubah}(h]h ]h"]h$]h&]uh1jIhj?ubeh}(h]h ]h"]h$]h&]uh1j)hjZhMhjubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubh)}(h]Used by the driver to indicate the specific rate transmission type for 802.11n transmissions.h]h]Used by the driver to indicate the specific rate transmission type for 802.11n transmissions.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsrate_info (C struct) c.rate_infohNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(h rate_infoh]j)}(hstruct rate_infoh](j)}(hjh]hstruct}(hjŎhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/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 rate_infoh]j)}(hjh]h rate_info}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjҎhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjҎhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjҎhMhjhhubj)}(hhh]h)}(hbitrate informationh]hbitrate information}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjҎhMubeh}(h]h ](j8structeh"]h$]h&]jj8jjjjjjjuh1jwhhhjcchNhNubj)}(hXm**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/UHR rate ``nss`` number of streams (VHT & HE only) ``bw`` bandwidth (from :c:type:`enum rate_info_bw `) ``he_gi`` HE guard interval (from :c:type:`enum nl80211_he_gi `) ``he_dcm`` HE DCM value ``he_ru_alloc`` HE RU allocation (from :c:type:`enum nl80211_he_ru_alloc `, only valid if bw is ``RATE_INFO_BW_HE_RU``) ``n_bonded_ch`` In case of EDMG the number of bonded channels (1-4) ``eht_gi`` EHT guard interval (from :c:type:`enum nl80211_eht_gi `) ``eht_ru_alloc`` EHT RU allocation (from :c:type:`enum nl80211_eht_ru_alloc `, only valid if bw is ``RATE_INFO_BW_EHT_RU``)h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj+hhhNhNubah}(h]h ]h"]h$]h&]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#ubj: )}(hstruct rate_info { u16 flags; u16 legacy; u8 mcs; u8 nss; u8 bw; u8 he_gi; u8 he_dcm; u8 he_ru_alloc; u8 n_bonded_ch; u8 eht_gi; u8 eht_ru_alloc; };h]hstruct rate_info { u16 flags; u16 legacy; u8 mcs; u8 nss; u8 bw; u8 he_gi; u8 he_dcm; u8 he_ru_alloc; u8 n_bonded_ch; u8 eht_gi; u8 eht_ru_alloc; };}hjDsbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj#ubh)}(h **Members**h]j)}(hjUh]hMembers}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj#ubj%)}(hhh](j*)}(hQ``flags`` bitflag of flags from :c:type:`enum rate_info_flags ` h](j0)}(h ``flags``h]j,)}(hjth]hflags}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjrubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjnubjJ)}(hhh]h)}(hFbitflag of flags from :c:type:`enum rate_info_flags `h](hbitflag of flags from }(hjhhhNhNubh)}(h0:c:type:`enum rate_info_flags `h]j,)}(hjh]henum rate_info_flags}(hjhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJrate_info_flagsuh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjnubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjkubj*)}(h.``legacy`` bitrate in 100kbit/s for 802.11abg h](j0)}(h ``legacy``h]j,)}(hj̏h]hlegacy}(hjΏhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjʏubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjƏubjJ)}(hhh]h)}(h"bitrate in 100kbit/s for 802.11abgh]h"bitrate in 100kbit/s for 802.11abg}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjƏubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjkubj*)}(hD``mcs`` mcs index if struct describes an HT/VHT/HE/EHT/S1G/UHR rate h](j0)}(h``mcs``h]j,)}(hjh]hmcs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h;mcs index if struct describes an HT/VHT/HE/EHT/S1G/UHR rateh]h;mcs index if struct describes an HT/VHT/HE/EHT/S1G/UHR rate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjkubj*)}(h*``nss`` number of streams (VHT & HE only) h](j0)}(h``nss``h]j,)}(hj>h]hnss}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj<ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj8ubjJ)}(hhh]h)}(h!number of streams (VHT & HE only)h]h!number of streams (VHT & HE only)}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShMhjTubah}(h]h ]h"]h$]h&]uh1jIhj8ubeh}(h]h ]h"]h$]h&]uh1j)hjShMhjkubj*)}(hC``bw`` bandwidth (from :c:type:`enum rate_info_bw `) h](j0)}(h``bw``h]j,)}(hjwh]hbw}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjuubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubjJ)}(hhh]h)}(h;bandwidth (from :c:type:`enum rate_info_bw `)h](hbandwidth (from }(hjhhhNhNubh)}(h*:c:type:`enum rate_info_bw `h]j,)}(hjh]henum rate_info_bw}(hjhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJ rate_info_bwuh1hhjhMhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjqubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjkubj*)}(hP``he_gi`` HE guard interval (from :c:type:`enum nl80211_he_gi `) h](j0)}(h ``he_gi``h]j,)}(hjӐh]hhe_gi}(hjՐhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjѐubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj͐ubjJ)}(hhh]h)}(hEHE guard interval (from :c:type:`enum nl80211_he_gi `)h](hHE guard interval (from }(hjhhhNhNubh)}(h,:c:type:`enum nl80211_he_gi `h]j,)}(hjh]henum nl80211_he_gi}(hjhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJ nl80211_he_giuh1hhjhMhjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhj͐ubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjkubj*)}(h``he_dcm`` HE DCM value h](j0)}(h ``he_dcm``h]j,)}(hj/h]hhe_dcm}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj-ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj)ubjJ)}(hhh]h)}(h HE DCM valueh]h HE DCM value}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDhMhjEubah}(h]h ]h"]h$]h&]uh1jIhj)ubeh}(h]h ]h"]h$]h&]uh1j)hjDhMhjkubj*)}(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](j0)}(h``he_ru_alloc``h]j,)}(hjhh]h he_ru_alloc}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjfubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjbubjJ)}(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 ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_he_ru_allocuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh, only valid if bw is }(hjhhhNhNubj,)}(h``RATE_INFO_BW_HE_RU``h]hRATE_INFO_BW_HE_RU}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhj~ubah}(h]h ]h"]h$]h&]uh1jIhjbubeh}(h]h ]h"]h$]h&]uh1j)hj}hMhjkubj*)}(hD``n_bonded_ch`` In case of EDMG the number of bonded channels (1-4) h](j0)}(h``n_bonded_ch``h]j,)}(hjבh]h n_bonded_ch}(hjّhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjՑubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjёubjJ)}(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&]uh1jIhjёubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjkubj*)}(hT``eht_gi`` EHT guard interval (from :c:type:`enum nl80211_eht_gi `) h](j0)}(h ``eht_gi``h]j,)}(hjh]heht_gi}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubjJ)}(hhh]h)}(hHEHT guard interval (from :c:type:`enum nl80211_eht_gi `)h](hEHT guard interval (from }(hj)hhhNhNubh)}(h.:c:type:`enum nl80211_eht_gi `h]j,)}(hj3h]henum nl80211_eht_gi}(hj5hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj1ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_eht_giuh1hhj%hMhj)ubh)}(hj)hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj%hMhj&ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj%hMhjkubj*)}(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](j0)}(h``eht_ru_alloc``h]j,)}(hjlh]h eht_ru_alloc}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjfubjJ)}(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 ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_eht_ru_allocuh1hhjhMhjubh, only valid if bw is }(hjhhhNhNubj,)}(h``RATE_INFO_BW_EHT_RU``h]hRATE_INFO_BW_EHT_RU}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjfubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjkubeh}(h]h ]h"]h$]h&]uh1j$hj#ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubh)}(h5Information about a receiving or transmitting bitrateh]h5Information about a receiving or transmitting bitrate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsstation_info (C struct)c.station_infohNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(h station_infoh]j)}(hstruct station_infoh](j)}(hjh]hstruct}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj.hMubj)}(h station_infoh]j)}(hjh]h station_info}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj.hMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhj.hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hj.hMhjhhubj)}(hhh]h)}(hstation informationh]hstation information}(hjchhhNhNubah}(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 ](j8structeh"]h$]h&]jj8jj{jj{jjjuh1jwhhhjcchNhNubj)}(hX**Definition**:: struct station_info { u64 filled; u32 connected_time; u32 inactive_time; u64 assoc_at; u64 rx_bytes; u64 tx_bytes; s8 signal; s8 signal_avg; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; s8 chain_signal_avg[IEEE80211_MAX_CHAINS]; struct rate_info txrate; struct rate_info rxrate; u32 rx_packets; u32 tx_packets; u32 tx_retries; u32 tx_failed; u32 rx_dropped_misc; struct sta_bss_parameters bss_param; struct nl80211_sta_flag_update sta_flags; int generation; u32 beacon_loss_count; const u8 *assoc_req_ies; size_t assoc_req_ies_len; s64 t_offset; u16 llid; u16 plid; u8 plink_state; u8 connected_to_gate; u8 connected_to_as; u32 airtime_link_metric; enum nl80211_mesh_power_mode local_pm; enum nl80211_mesh_power_mode peer_pm; enum nl80211_mesh_power_mode nonpeer_pm; u32 expected_throughput; u16 airtime_weight; s8 ack_signal; s8 avg_ack_signal; struct cfg80211_tid_stats *pertid; u64 tx_duration; u64 rx_duration; u64 rx_beacon; u8 rx_beacon_signal_avg; u32 rx_mpdu_count; u32 fcs_err_count; bool mlo_params_valid; u8 assoc_link_id; u8 mld_addr[ETH_ALEN]; const u8 *assoc_resp_ies; size_t assoc_resp_ies_len; u16 valid_links; struct link_station_info *links[IEEE80211_MLD_MAX_NUM_LINKS]; }; **Members** ``filled`` bitflag of flags using the bits of :c:type:`enum nl80211_sta_info ` to indicate the relevant values in this struct for them ``connected_time`` time(in secs) since a station is last connected ``inactive_time`` time since last station activity (tx/rx) in milliseconds ``assoc_at`` bootime (ns) of the last association ``rx_bytes`` bytes (size of MPDUs) received from this station ``tx_bytes`` bytes (size of MPDUs) transmitted to this station ``signal`` The signal strength, type depends on the wiphy's signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_. ``signal_avg`` Average signal strength, type depends on the wiphy's signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_. ``chains`` bitmask for filled values in **chain_signal**, **chain_signal_avg** ``chain_signal`` per-chain signal strength of last received packet in dBm ``chain_signal_avg`` per-chain signal strength average in dBm ``txrate`` current unicast bitrate from this station ``rxrate`` current unicast bitrate to this station ``rx_packets`` packets (MSDUs & MMPDUs) received from this station ``tx_packets`` packets (MSDUs & MMPDUs) transmitted to this station ``tx_retries`` cumulative retry counts (MPDUs) ``tx_failed`` number of failed transmissions (MPDUs) (retries exceeded, no ACK) ``rx_dropped_misc`` Dropped for un-specified reason. ``bss_param`` current BSS parameters ``sta_flags`` station flags mask & values ``generation`` generation number for nl80211 dumps. This number should increase every time the list of stations changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot. ``beacon_loss_count`` Number of times beacon loss event has triggered. ``assoc_req_ies`` IEs from (Re)Association Request. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided for the cfg80211_new_sta() calls to notify user space of the IEs. ``assoc_req_ies_len`` Length of assoc_req_ies buffer in octets. ``t_offset`` Time offset of the station relative to this host. ``llid`` mesh local link id ``plid`` mesh peer link id ``plink_state`` mesh peer link state ``connected_to_gate`` true if mesh STA has a path to mesh gate ``connected_to_as`` true if mesh STA has a path to authentication server ``airtime_link_metric`` mesh airtime link metric. ``local_pm`` local mesh STA power save mode ``peer_pm`` peer mesh STA power save mode ``nonpeer_pm`` non-peer mesh STA power save mode ``expected_throughput`` expected throughput in kbps (including 802.11 headers) towards this station. ``airtime_weight`` current airtime scheduling weight ``ack_signal`` signal strength (in dBm) of the last ACK frame. ``avg_ack_signal`` average rssi value of ack packet for the no of msdu's has been sent. ``pertid`` per-TID statistics, see :c:type:`struct cfg80211_tid_stats `, using the last (IEEE80211_NUM_TIDS) index for MSDUs not encapsulated in QoS-MPDUs. Note that this doesn't use the **filled** bit, but is used if non-NULL. ``tx_duration`` aggregate PPDU duration(usecs) for all the frames to a peer ``rx_duration`` aggregate PPDU duration(usecs) for all the frames from a peer ``rx_beacon`` number of beacons received from this peer ``rx_beacon_signal_avg`` signal strength average (in dBm) for beacons received from this peer ``rx_mpdu_count`` number of MPDUs received from this station ``fcs_err_count`` number of packets (MPDUs) received from this station with an FCS error. This counter should be incremented only when TA of the received packet with an FCS error matches the peer MAC address. ``mlo_params_valid`` Indicates **assoc_link_id** and **mld_addr** fields are filled by driver. Drivers use this only in cfg80211_new_sta() calls when AP MLD's MLME/SME is offload to driver. Drivers won't fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. ``assoc_link_id`` Indicates MLO link ID of the AP, with which the station completed (re)association. This information filled for both MLO and non-MLO STA connections when the AP affiliated with an MLD. ``mld_addr`` For MLO STA connection, filled with MLD address of the station. For non-MLO STA connection, filled with all zeros. ``assoc_resp_ies`` IEs from (Re)Association Response. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided only for the cfg80211_new_sta() calls to notify user space of the IEs. Drivers won't fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. User space needs this information to determine the accepted and rejected affiliated links of the connected station. ``assoc_resp_ies_len`` Length of **assoc_resp_ies** buffer in octets. ``valid_links`` bitmap of valid links, or 0 for non-MLO. Drivers fill this information in cfg80211_new_sta(), cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. ``links`` reference to Link sta entries for MLO STA, all link specific information is accessed through links[link_id].h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(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; u16 valid_links; struct link_station_info *links[IEEE80211_MLD_MAX_NUM_LINKS]; };h]hX|struct station_info { u64 filled; u32 connected_time; u32 inactive_time; u64 assoc_at; u64 rx_bytes; u64 tx_bytes; s8 signal; s8 signal_avg; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; s8 chain_signal_avg[IEEE80211_MAX_CHAINS]; struct rate_info txrate; struct rate_info rxrate; u32 rx_packets; u32 tx_packets; u32 tx_retries; u32 tx_failed; u32 rx_dropped_misc; struct sta_bss_parameters bss_param; struct nl80211_sta_flag_update sta_flags; int generation; u32 beacon_loss_count; const u8 *assoc_req_ies; size_t assoc_req_ies_len; s64 t_offset; u16 llid; u16 plid; u8 plink_state; u8 connected_to_gate; u8 connected_to_as; u32 airtime_link_metric; enum nl80211_mesh_power_mode local_pm; enum nl80211_mesh_power_mode peer_pm; enum nl80211_mesh_power_mode nonpeer_pm; u32 expected_throughput; u16 airtime_weight; s8 ack_signal; s8 avg_ack_signal; struct cfg80211_tid_stats *pertid; u64 tx_duration; u64 rx_duration; u64 rx_beacon; u8 rx_beacon_signal_avg; u32 rx_mpdu_count; u32 fcs_err_count; bool mlo_params_valid; u8 assoc_link_id; u8 mld_addr[ETH_ALEN]; const u8 *assoc_resp_ies; size_t assoc_resp_ies_len; u16 valid_links; struct link_station_info *links[IEEE80211_MLD_MAX_NUM_LINKS]; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j9 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&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubj%)}(hhh](j*)}(h``filled`` bitflag of flags using the bits of :c:type:`enum nl80211_sta_info ` to indicate the relevant values in this struct for them h](j0)}(h ``filled``h]j,)}(hjГh]hfilled}(hjғhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjΓubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjʓubjJ)}(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 ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_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&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjʓubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(hC``connected_time`` time(in secs) since a station is last connected h](j0)}(h``connected_time``h]j,)}(hj-h]hconnected_time}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj+ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj'ubjJ)}(hhh]h)}(h/time(in secs) since a station is last connectedh]h/time(in secs) since a station is last connected}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhMhjCubah}(h]h ]h"]h$]h&]uh1jIhj'ubeh}(h]h ]h"]h$]h&]uh1j)hjBhMhjǓubj*)}(hK``inactive_time`` time since last station activity (tx/rx) in milliseconds h](j0)}(h``inactive_time``h]j,)}(hjfh]h inactive_time}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjdubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj`ubjJ)}(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&]uh1hhj{hMhj|ubah}(h]h ]h"]h$]h&]uh1jIhj`ubeh}(h]h ]h"]h$]h&]uh1j)hj{hMhjǓubj*)}(h2``assoc_at`` bootime (ns) of the last association h](j0)}(h ``assoc_at``h]j,)}(hjh]hassoc_at}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h$bootime (ns) of the last associationh]h$bootime (ns) of the last association}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h>``rx_bytes`` bytes (size of MPDUs) received from this station h](j0)}(h ``rx_bytes``h]j,)}(hjؔh]hrx_bytes}(hjڔhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj֔ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjҔubjJ)}(hhh]h)}(h0bytes (size of MPDUs) received from this stationh]h0bytes (size of MPDUs) received from this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjҔubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h?``tx_bytes`` bytes (size of MPDUs) transmitted to this station h](j0)}(h ``tx_bytes``h]j,)}(hjh]htx_bytes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubjJ)}(hhh]h)}(h1bytes (size of MPDUs) transmitted to this stationh]h1bytes (size of MPDUs) transmitted to this station}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMhj'ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj&hMhjǓubj*)}(h``signal`` The signal strength, type depends on the wiphy's signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_. h](j0)}(h ``signal``h]j,)}(hjJh]hsignal}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjHubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjDubjJ)}(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_.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj`ubah}(h]h ]h"]h$]h&]uh1jIhjDubeh}(h]h ]h"]h$]h&]uh1j)hj_hMhjǓubj*)}(h``signal_avg`` Average signal strength, type depends on the wiphy's signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_. h](j0)}(h``signal_avg``h]j,)}(hjh]h signal_avg}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj~ubjJ)}(hhh]h)}(h|Average signal strength, type depends on the wiphy's signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_.h]h~Average signal strength, type depends on the wiphy’s signal_type. For CFG80211_SIGNAL_TYPE_MBM, value is expressed in _dBm_.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhj~ubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(hO``chains`` bitmask for filled values in **chain_signal**, **chain_signal_avg** h](j0)}(h ``chains``h]j,)}(hjh]hchains}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hCbitmask for filled values in **chain_signal**, **chain_signal_avg**h](hbitmask for filled values in }(hjוhhhNhNubj)}(h**chain_signal**h]h chain_signal}(hjߕhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjוubh, }(hjוhhhNhNubj)}(h**chain_signal_avg**h]hchain_signal_avg}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjוubeh}(h]h ]h"]h$]h&]uh1hhjӕhMhjԕubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjӕhMhjǓubj*)}(hJ``chain_signal`` per-chain signal strength of last received packet in dBm h](j0)}(h``chain_signal``h]j,)}(hjh]h chain_signal}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h8per-chain signal strength of last received packet in dBmh]h8per-chain signal strength of last received packet in dBm}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,hMhj-ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj,hMhjǓubj*)}(h>``chain_signal_avg`` per-chain signal strength average in dBm h](j0)}(h``chain_signal_avg``h]j,)}(hjPh]hchain_signal_avg}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjNubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjJubjJ)}(hhh]h)}(h(per-chain signal strength average in dBmh]h(per-chain signal strength average in dBm}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMhjfubah}(h]h ]h"]h$]h&]uh1jIhjJubeh}(h]h ]h"]h$]h&]uh1j)hjehMhjǓubj*)}(h5``txrate`` current unicast bitrate from this station h](j0)}(h ``txrate``h]j,)}(hjh]htxrate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h)current unicast bitrate from this stationh]h)current unicast bitrate from this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h3``rxrate`` current unicast bitrate to this station h](j0)}(h ``rxrate``h]j,)}(hj–h]hrxrate}(hjĖhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h'current unicast bitrate to this stationh]h'current unicast bitrate to this station}(hjۖhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjזhMhjؖubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjזhMhjǓubj*)}(hC``rx_packets`` packets (MSDUs & MMPDUs) received from this station h](j0)}(h``rx_packets``h]j,)}(hjh]h rx_packets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h3packets (MSDUs & MMPDUs) received from this stationh]h3packets (MSDUs & MMPDUs) received from this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(hD``tx_packets`` packets (MSDUs & MMPDUs) transmitted to this station h](j0)}(h``tx_packets``h]j,)}(hj4h]h tx_packets}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj2ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj.ubjJ)}(hhh]h)}(h4packets (MSDUs & MMPDUs) transmitted to this stationh]h4packets (MSDUs & MMPDUs) transmitted to this station}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhMhjJubah}(h]h ]h"]h$]h&]uh1jIhj.ubeh}(h]h ]h"]h$]h&]uh1j)hjIhMhjǓubj*)}(h/``tx_retries`` cumulative retry counts (MPDUs) h](j0)}(h``tx_retries``h]j,)}(hjmh]h tx_retries}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjkubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjgubjJ)}(hhh]h)}(hcumulative retry counts (MPDUs)h]hcumulative retry counts (MPDUs)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjgubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(hP``tx_failed`` number of failed transmissions (MPDUs) (retries exceeded, no ACK) h](j0)}(h ``tx_failed``h]j,)}(hjh]h tx_failed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h5``rx_dropped_misc`` Dropped for un-specified reason. h](j0)}(h``rx_dropped_misc``h]j,)}(hjߗh]hrx_dropped_misc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjݗubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjٗubjJ)}(hhh]h)}(h Dropped for un-specified reason.h]h Dropped for un-specified reason.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjٗubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h%``bss_param`` current BSS parameters h](j0)}(h ``bss_param``h]j,)}(hjh]h bss_param}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hcurrent BSS parametersh]hcurrent BSS parameters}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-hMhj.ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj-hMhjǓubj*)}(h*``sta_flags`` station flags mask & values h](j0)}(h ``sta_flags``h]j,)}(hjQh]h sta_flags}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjOubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjKubjJ)}(hhh]h)}(hstation flags mask & valuesh]hstation flags mask & values}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjgubah}(h]h ]h"]h$]h&]uh1jIhjKubeh}(h]h ]h"]h$]h&]uh1j)hjfhMhjǓubj*)}(h``generation`` generation number for nl80211 dumps. This number should increase every time the list of stations changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot. h](j0)}(h``generation``h]j,)}(hjh]h generation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hgeneration number for nl80211 dumps. This number should increase every time the list of stations changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.h]hgeneration number for nl80211 dumps. This number should increase every time the list of stations changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(hG``beacon_loss_count`` Number of times beacon loss event has triggered. h](j0)}(h``beacon_loss_count``h]j,)}(hjĘh]hbeacon_loss_count}(hjƘhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj˜ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h0Number of times beacon loss event has triggered.h]h0Number of times beacon loss event has triggered.}(hjݘhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj٘hMhjژubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj٘hMhjǓubj*)}(h``assoc_req_ies`` IEs from (Re)Association Request. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided for the cfg80211_new_sta() calls to notify user space of the IEs. h](j0)}(h``assoc_req_ies``h]j,)}(hjh]h assoc_req_ies}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hIEs from (Re)Association Request. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided for the cfg80211_new_sta() calls to notify user space of the IEs.h]hIEs from (Re)Association Request. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided for the cfg80211_new_sta() calls to notify user space of the IEs.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h@``assoc_req_ies_len`` Length of assoc_req_ies buffer in octets. h](j0)}(h``assoc_req_ies_len``h]j,)}(hj7h]hassoc_req_ies_len}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj5ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj1ubjJ)}(hhh]h)}(h)Length of assoc_req_ies buffer in octets.h]h)Length of assoc_req_ies buffer in octets.}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMhjMubah}(h]h ]h"]h$]h&]uh1jIhj1ubeh}(h]h ]h"]h$]h&]uh1j)hjLhMhjǓubj*)}(h?``t_offset`` Time offset of the station relative to this host. h](j0)}(h ``t_offset``h]j,)}(hjph]ht_offset}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjnubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjjubjJ)}(hhh]h)}(h1Time offset of the station relative to this host.h]h1Time offset of the station relative to this host.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h``llid`` mesh local link id h](j0)}(h``llid``h]j,)}(hjh]hllid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hmesh local link idh]hmesh local link id}(hj™hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h``plid`` mesh peer link id h](j0)}(h``plid``h]j,)}(hjh]hplid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjܙubjJ)}(hhh]h)}(hmesh peer link idh]hmesh peer link id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjܙubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h%``plink_state`` mesh peer link state h](j0)}(h``plink_state``h]j,)}(hjh]h plink_state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hmesh peer link stateh]hmesh peer link state}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0hMhj1ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj0hMhjǓubj*)}(h?``connected_to_gate`` true if mesh STA has a path to mesh gate h](j0)}(h``connected_to_gate``h]j,)}(hjTh]hconnected_to_gate}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjRubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjNubjJ)}(hhh]h)}(h(true if mesh STA has a path to mesh gateh]h(true if mesh STA has a path to mesh gate}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhjjubah}(h]h ]h"]h$]h&]uh1jIhjNubeh}(h]h ]h"]h$]h&]uh1j)hjihMhjǓubj*)}(hI``connected_to_as`` true if mesh STA has a path to authentication server h](j0)}(h``connected_to_as``h]j,)}(hjh]hconnected_to_as}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h4true if mesh STA has a path to authentication serverh]h4true if mesh STA has a path to authentication server}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h2``airtime_link_metric`` mesh airtime link metric. h](j0)}(h``airtime_link_metric``h]j,)}(hjƚh]hairtime_link_metric}(hjȚhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjĚubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hmesh airtime link metric.h]hmesh airtime link metric.}(hjߚhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjۚhMhjܚubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjۚhMhjǓubj*)}(h,``local_pm`` local mesh STA power save mode h](j0)}(h ``local_pm``h]j,)}(hjh]hlocal_pm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hlocal mesh STA power save modeh]hlocal mesh STA power save mode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h*``peer_pm`` peer mesh STA power save mode h](j0)}(h ``peer_pm``h]j,)}(hj8h]hpeer_pm}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj2ubjJ)}(hhh]h)}(hpeer mesh STA power save modeh]hpeer mesh STA power save mode}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMhMhjNubah}(h]h ]h"]h$]h&]uh1jIhj2ubeh}(h]h ]h"]h$]h&]uh1j)hjMhMhjǓubj*)}(h1``nonpeer_pm`` non-peer mesh STA power save mode h](j0)}(h``nonpeer_pm``h]j,)}(hjqh]h nonpeer_pm}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjoubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjkubjJ)}(hhh]h)}(h!non-peer mesh STA power save modeh]h!non-peer mesh STA power save mode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjkubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(he``expected_throughput`` expected throughput in kbps (including 802.11 headers) towards this station. h](j0)}(h``expected_throughput``h]j,)}(hjh]hexpected_throughput}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hLexpected throughput in kbps (including 802.11 headers) towards this station.h]hLexpected throughput in kbps (including 802.11 headers) towards this station.}(hjÛhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h5``airtime_weight`` current airtime scheduling weight h](j0)}(h``airtime_weight``h]j,)}(hjh]hairtime_weight}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjޛubjJ)}(hhh]h)}(h!current airtime scheduling weighth]h!current airtime scheduling weight}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjޛubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h?``ack_signal`` signal strength (in dBm) of the last ACK frame. h](j0)}(h``ack_signal``h]j,)}(hjh]h ack_signal}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h/signal strength (in dBm) of the last ACK frame.h]h/signal strength (in dBm) of the last ACK frame.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hMhj3ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj2hMhjǓubj*)}(hX``avg_ack_signal`` average rssi value of ack packet for the no of msdu's has been sent. h](j0)}(h``avg_ack_signal``h]j,)}(hjVh]havg_ack_signal}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjTubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjPubjJ)}(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.}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjlubah}(h]h ]h"]h$]h&]uh1jIhjPubeh}(h]h ]h"]h$]h&]uh1j)hjkhMhjǓubj*)}(h``pertid`` per-TID statistics, see :c:type:`struct cfg80211_tid_stats `, using the last (IEEE80211_NUM_TIDS) index for MSDUs not encapsulated in QoS-MPDUs. Note that this doesn't use the **filled** bit, but is used if non-NULL. h](j0)}(h ``pertid``h]j,)}(hjh]hpertid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hper-TID statistics, see :c:type:`struct cfg80211_tid_stats `, using the last (IEEE80211_NUM_TIDS) index for MSDUs not encapsulated in QoS-MPDUs. Note that this doesn't use the **filled** bit, but is used if non-NULL.h](hper-TID statistics, see }(hjhhhNhNubh)}(h8:c:type:`struct cfg80211_tid_stats `h]j,)}(hjh]hstruct cfg80211_tid_stats}(hjhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJcfg80211_tid_statsuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubhv, using the last (IEEE80211_NUM_TIDS) index for MSDUs not encapsulated in QoS-MPDUs. Note that this doesn’t use the }(hjhhhNhNubj)}(h **filled**h]hfilled}(hj՜hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh bit, but is used if non-NULL.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjМhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(hL``tx_duration`` aggregate PPDU duration(usecs) for all the frames to a peer h](j0)}(h``tx_duration``h]j,)}(hjh]h tx_duration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h;aggregate PPDU duration(usecs) for all the frames to a peerh]h;aggregate PPDU duration(usecs) for all the frames to a peer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(hN``rx_duration`` aggregate PPDU duration(usecs) for all the frames from a peer h](j0)}(h``rx_duration``h]j,)}(hj8h]h rx_duration}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj2ubjJ)}(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}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMhMhjNubah}(h]h ]h"]h$]h&]uh1jIhj2ubeh}(h]h ]h"]h$]h&]uh1j)hjMhMhjǓubj*)}(h8``rx_beacon`` number of beacons received from this peer h](j0)}(h ``rx_beacon``h]j,)}(hjqh]h rx_beacon}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjoubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjkubjJ)}(hhh]h)}(h)number of beacons received from this peerh]h)number of beacons received from this peer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjkubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h^``rx_beacon_signal_avg`` signal strength average (in dBm) for beacons received from this peer h](j0)}(h``rx_beacon_signal_avg``h]j,)}(hjh]hrx_beacon_signal_avg}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hDsignal strength average (in dBm) for beacons received from this peerh]hDsignal strength average (in dBm) for beacons received from this peer}(hjÝhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h=``rx_mpdu_count`` number of MPDUs received from this station h](j0)}(h``rx_mpdu_count``h]j,)}(hjh]h rx_mpdu_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjޝubjJ)}(hhh]h)}(h*number of MPDUs received from this stationh]h*number of MPDUs received from this station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjޝubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(h``fcs_err_count`` number of packets (MPDUs) received from this station with an FCS error. This counter should be incremented only when TA of the received packet with an FCS error matches the peer MAC address. h](j0)}(h``fcs_err_count``h]j,)}(hjh]h fcs_err_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj3ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj2hMhjǓubj*)}(hX+``mlo_params_valid`` Indicates **assoc_link_id** and **mld_addr** fields are filled by driver. Drivers use this only in cfg80211_new_sta() calls when AP MLD's MLME/SME is offload to driver. Drivers won't fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. h](j0)}(h``mlo_params_valid``h]j,)}(hjWh]hmlo_params_valid}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjUubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjQubjJ)}(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 }(hjphhhNhNubj)}(h**assoc_link_id**h]h assoc_link_id}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubh and }(hjphhhNhNubj)}(h **mld_addr**h]hmld_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubh 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.}(hjphhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjmubah}(h]h ]h"]h$]h&]uh1jIhjQubeh}(h]h ]h"]h$]h&]uh1j)hjlhMhjǓubj*)}(h``assoc_link_id`` Indicates MLO link ID of the AP, with which the station completed (re)association. This information filled for both MLO and non-MLO STA connections when the AP affiliated with an MLD. h](j0)}(h``assoc_link_id``h]j,)}(hjh]h assoc_link_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hIndicates MLO link ID of the AP, with which the station completed (re)association. This information filled for both MLO and non-MLO STA connections when the AP affiliated with an MLD.h]hIndicates MLO link ID of the AP, with which the station completed (re)association. This information filled for both MLO and non-MLO STA connections when the AP affiliated with an MLD.}(hjΞhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj˞ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjʞhMhjǓubj*)}(h``mld_addr`` For MLO STA connection, filled with MLD address of the station. For non-MLO STA connection, filled with all zeros. h](j0)}(h ``mld_addr``h]j,)}(hjh]hmld_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hrFor MLO STA connection, filled with MLD address of the station. For non-MLO STA connection, filled with all zeros.h]hrFor MLO STA connection, filled with MLD address of the station. For non-MLO STA connection, filled with all zeros.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhjǓubj*)}(hX``assoc_resp_ies`` IEs from (Re)Association Response. This is used only when in AP mode with drivers that do not use user space MLME/SME implementation. The information is provided only for the cfg80211_new_sta() calls to notify user space of the IEs. Drivers won't fill this information in cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. User space needs this information to determine the accepted and rejected affiliated links of the connected station. h](j0)}(h``assoc_resp_ies``h]j,)}(hj)h]hassoc_resp_ies}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj'ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj#ubjJ)}(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.}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj?ubah}(h]h ]h"]h$]h&]uh1jIhj#ubeh}(h]h ]h"]h$]h&]uh1j)hj>hMhjǓubj*)}(hF``assoc_resp_ies_len`` Length of **assoc_resp_ies** buffer in octets. h](j0)}(h``assoc_resp_ies_len``h]j,)}(hjch]hassoc_resp_ies_len}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjaubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj]ubjJ)}(hhh]h)}(h.Length of **assoc_resp_ies** buffer in octets.h](h Length of }(hj|hhhNhNubj)}(h**assoc_resp_ies**h]hassoc_resp_ies}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubh buffer in octets.}(hj|hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjxhM hjyubah}(h]h ]h"]h$]h&]uh1jIhj]ubeh}(h]h ]h"]h$]h&]uh1j)hjxhM hjǓubj*)}(h``valid_links`` bitmap of valid links, or 0 for non-MLO. Drivers fill this information in cfg80211_new_sta(), cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks. h](j0)}(h``valid_links``h]j,)}(hjh]h valid_links}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hbitmap of valid links, or 0 for non-MLO. Drivers fill this information in cfg80211_new_sta(), cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks.h]hbitmap of valid links, or 0 for non-MLO. Drivers fill this information in cfg80211_new_sta(), cfg80211_del_sta_sinfo(), get_station() and dump_station() callbacks.}(hjǟhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjğubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjßhM hjǓubj*)}(hv``links`` reference to Link sta entries for MLO STA, all link specific information is accessed through links[link_id].h](j0)}(h ``links``h]j,)}(hjh]hlinks}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hlreference to Link sta entries for MLO STA, all link specific information is accessed through links[link_id].h]hlreference to Link sta entries for MLO STA, all link specific information is accessed through links[link_id].}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjǓubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hj*h]h Description}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubh)}(hHStation information filled by driver for get_station() and dump_station.h]hHStation information filled by driver for get_station() and dump_station.}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsmonitor_flags (C enum)c.monitor_flagshNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(h monitor_flagsh]j)}(henum monitor_flagsh](j)}(hjh]henum}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMubj)}(h h]h }(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdhhhjuhMubj)}(h monitor_flagsh]j)}(hjbh]h monitor_flags}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjdhhhjuhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj`hhhjuhMubah}(h]j[ah ](jjeh"]h$]h&]jj)jhuh1j|hjuhMhj]hhubj)}(hhh]h)}(h monitor flagsh]h monitor flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhj]hhhjuhMubeh}(h]h ](j8enumeh"]h$]h&]jj8jj jj jjjuh1jwhhhjcchNhNubj)}(hX**Constants** ``MONITOR_FLAG_CHANGED`` set if the flags were changed ``MONITOR_FLAG_FCSFAIL`` pass frames with bad FCS ``MONITOR_FLAG_PLCPFAIL`` pass frames with bad PLCP ``MONITOR_FLAG_CONTROL`` pass control frames ``MONITOR_FLAG_OTHER_BSS`` disable BSSID filtering ``MONITOR_FLAG_COOK_FRAMES`` deprecated, will unconditionally be refused ``MONITOR_FLAG_ACTIVE`` active monitor, ACKs frames on its MAC address ``MONITOR_FLAG_SKIP_TX`` do not pass locally transmitted framesh](h)}(h **Constants**h]j)}(hj̠h]h Constants}(hjΠhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjʠ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*)}(h7``MONITOR_FLAG_CHANGED`` set if the flags were changed h](j0)}(h``MONITOR_FLAG_CHANGED``h]j,)}(hjh]hMONITOR_FLAG_CHANGED}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hset if the flags were changedh]hset if the flags were changed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h2``MONITOR_FLAG_FCSFAIL`` pass frames with bad FCS h](j0)}(h``MONITOR_FLAG_FCSFAIL``h]j,)}(hj$h]hMONITOR_FLAG_FCSFAIL}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj"ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hpass frames with bad FCSh]hpass frames with bad FCS}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hM hj:ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj9hM hjubj*)}(h4``MONITOR_FLAG_PLCPFAIL`` pass frames with bad PLCP h](j0)}(h``MONITOR_FLAG_PLCPFAIL``h]j,)}(hj]h]hMONITOR_FLAG_PLCPFAIL}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj[ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjWubjJ)}(hhh]h)}(hpass frames with bad PLCPh]hpass frames with bad PLCP}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrhM hjsubah}(h]h ]h"]h$]h&]uh1jIhjWubeh}(h]h ]h"]h$]h&]uh1j)hjrhM hjubj*)}(h-``MONITOR_FLAG_CONTROL`` pass control frames h](j0)}(h``MONITOR_FLAG_CONTROL``h]j,)}(hjh]hMONITOR_FLAG_CONTROL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hpass control framesh]hpass control frames}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h3``MONITOR_FLAG_OTHER_BSS`` disable BSSID filtering h](j0)}(h``MONITOR_FLAG_OTHER_BSS``h]j,)}(hjϡh]hMONITOR_FLAG_OTHER_BSS}(hjѡhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj͡ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjɡubjJ)}(hhh]h)}(hdisable BSSID filteringh]hdisable BSSID filtering}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjɡubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(hI``MONITOR_FLAG_COOK_FRAMES`` deprecated, will unconditionally be refused h](j0)}(h``MONITOR_FLAG_COOK_FRAMES``h]j,)}(hjh]hMONITOR_FLAG_COOK_FRAMES}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h+deprecated, will unconditionally be refusedh]h+deprecated, will unconditionally be refused}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(hG``MONITOR_FLAG_ACTIVE`` active monitor, ACKs frames on its MAC address h](j0)}(h``MONITOR_FLAG_ACTIVE``h]j,)}(hjAh]hMONITOR_FLAG_ACTIVE}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj?ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj;ubjJ)}(hhh]h)}(h.active monitor, ACKs frames on its MAC addressh]h.active monitor, ACKs frames on its MAC address}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhM hjWubah}(h]h ]h"]h$]h&]uh1jIhj;ubeh}(h]h ]h"]h$]h&]uh1j)hjVhM hjubj*)}(h?``MONITOR_FLAG_SKIP_TX`` do not pass locally transmitted framesh](j0)}(h``MONITOR_FLAG_SKIP_TX``h]j,)}(hjzh]hMONITOR_FLAG_SKIP_TX}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjxubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjtubjJ)}(hhh]h)}(h&do not pass locally transmitted framesh]h&do not pass locally transmitted frames}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1jIhjtubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubeh}(h]h ]h"]h$]h&]uh1j$hjƠubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubh)}(hgMonitor interface configuration flags. Note that these must be the bits according to the nl80211 flags.h]hgMonitor interface configuration flags. Note that these must be the bits according to the nl80211 flags.}(hjӢhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsmpath_info_flags (C enum)c.mpath_info_flagshNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hmpath_info_flagsh]j)}(henum mpath_info_flagsh](j)}(hjh]henum}(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&]uh1jhjhhhjhM ubj)}(hmpath_info_flagsh]j)}(hjh]hmpath_info_flags}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhM hjhhubj)}(hhh]h)}(hmesh path information flagsh]hmesh path information flags}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj:hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j8enumeh"]h$]h&]jj8jjUjjUjjjuh1jwhhhjcchNhNubj)}(hX**Constants** ``MPATH_INFO_FRAME_QLEN`` **frame_qlen** filled ``MPATH_INFO_SN`` **sn** filled ``MPATH_INFO_METRIC`` **metric** filled ``MPATH_INFO_EXPTIME`` **exptime** filled ``MPATH_INFO_DISCOVERY_TIMEOUT`` **discovery_timeout** filled ``MPATH_INFO_DISCOVERY_RETRIES`` **discovery_retries** filled ``MPATH_INFO_FLAGS`` **flags** filled ``MPATH_INFO_HOP_COUNT`` **hop_count** filled ``MPATH_INFO_PATH_CHANGE`` **path_change_count** filledh](h)}(h **Constants**h]j)}(hj_h]h Constants}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjYubj%)}(hhh](j*)}(h0``MPATH_INFO_FRAME_QLEN`` **frame_qlen** filled h](j0)}(h``MPATH_INFO_FRAME_QLEN``h]j,)}(hj~h]hMPATH_INFO_FRAME_QLEN}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj|ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjxubjJ)}(hhh]h)}(h**frame_qlen** filledh](j)}(h**frame_qlen**h]h frame_qlen}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh filled}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjxubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjuubj*)}(h ``MPATH_INFO_SN`` **sn** filled h](j0)}(h``MPATH_INFO_SN``h]j,)}(hjţh]h MPATH_INFO_SN}(hjǣhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjãubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h **sn** filledh](j)}(h**sn**h]hsn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjޣubh filled}(hjޣhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjڣhM hjۣubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjڣhM hjuubj*)}(h(``MPATH_INFO_METRIC`` **metric** filled h](j0)}(h``MPATH_INFO_METRIC``h]j,)}(hj h]hMPATH_INFO_METRIC}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h**metric** filledh](j)}(h **metric**h]hmetric}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubh filled}(hj%hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj!hM hj"ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj!hM hjuubj*)}(h*``MPATH_INFO_EXPTIME`` **exptime** filled h](j0)}(h``MPATH_INFO_EXPTIME``h]j,)}(hjSh]hMPATH_INFO_EXPTIME}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjQubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjMubjJ)}(hhh]h)}(h**exptime** filledh](j)}(h **exptime**h]hexptime}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubh filled}(hjlhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhhM hjiubah}(h]h ]h"]h$]h&]uh1jIhjMubeh}(h]h ]h"]h$]h&]uh1j)hjhhM hjuubj*)}(h>``MPATH_INFO_DISCOVERY_TIMEOUT`` **discovery_timeout** filled h](j0)}(h ``MPATH_INFO_DISCOVERY_TIMEOUT``h]j,)}(hjh]hMPATH_INFO_DISCOVERY_TIMEOUT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h**discovery_timeout** filledh](j)}(h**discovery_timeout**h]hdiscovery_timeout}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh filled}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjuubj*)}(h>``MPATH_INFO_DISCOVERY_RETRIES`` **discovery_retries** filled h](j0)}(h ``MPATH_INFO_DISCOVERY_RETRIES``h]j,)}(hjh]hMPATH_INFO_DISCOVERY_RETRIES}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjߤubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjۤubjJ)}(hhh]h)}(h**discovery_retries** filledh](j)}(h**discovery_retries**h]hdiscovery_retries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh filled}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjۤubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjuubj*)}(h&``MPATH_INFO_FLAGS`` **flags** filled h](j0)}(h``MPATH_INFO_FLAGS``h]j,)}(hj(h]hMPATH_INFO_FLAGS}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj&ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj"ubjJ)}(hhh]h)}(h**flags** filledh](j)}(h **flags**h]hflags}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubh filled}(hjAhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj=hM hj>ubah}(h]h ]h"]h$]h&]uh1jIhj"ubeh}(h]h ]h"]h$]h&]uh1j)hj=hM hjuubj*)}(h.``MPATH_INFO_HOP_COUNT`` **hop_count** filled h](j0)}(h``MPATH_INFO_HOP_COUNT``h]j,)}(hjoh]hMPATH_INFO_HOP_COUNT}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjmubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjiubjJ)}(hhh]h)}(h**hop_count** filledh](j)}(h **hop_count**h]h hop_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh filled}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjuubj*)}(h7``MPATH_INFO_PATH_CHANGE`` **path_change_count** filledh](j0)}(h``MPATH_INFO_PATH_CHANGE``h]j,)}(hjh]hMPATH_INFO_PATH_CHANGE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h**path_change_count** filledh](j)}(h**path_change_count**h]hpath_change_count}(hjӥhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjϥubh filled}(hjϥhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj̥ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj˥hM hjuubeh}(h]h ]h"]h$]h&]uh1j$hjYubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubh)}(hUsed by the driver to indicate which info in :c:type:`struct mpath_info ` it has filled in during get_station() or dump_station().h](h-Used by the driver to indicate which info in }(hjhhhNhNubh)}(h(:c:type:`struct mpath_info `h]j,)}(hj'h]hstruct mpath_info}(hj)hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj%ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJ mpath_infouh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubh9 it has filled in during get_station() or dump_station().}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjDhM hjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsmpath_info (C struct) c.mpath_infohNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(h mpath_infoh]j)}(hstruct mpath_infoh](j)}(hjh]hstruct}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdhhhjuhM ubj)}(h mpath_infoh]j)}(hjbh]h mpath_info}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjdhhhjuhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj`hhhjuhM ubah}(h]j[ah ](jjeh"]h$]h&]jj)jhuh1j|hjuhM hj]hhubj)}(hhh]h)}(hmesh path informationh]hmesh path information}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhj]hhhjuhM ubeh}(h]h ](j8structeh"]h$]h&]jj8jj¦jj¦jjjuh1jwhhhjcchNhNubj)}(hXs**Definition**:: struct mpath_info { u32 filled; u32 frame_qlen; u32 sn; u32 metric; u32 exptime; u32 discovery_timeout; u8 discovery_retries; u8 flags; u8 hop_count; u32 path_change_count; int generation; }; **Members** ``filled`` bitfield of flags from :c:type:`enum mpath_info_flags ` ``frame_qlen`` number of queued frames for this destination ``sn`` target sequence number ``metric`` metric (cost) of this mesh path ``exptime`` expiration time for the mesh path from now, in msecs ``discovery_timeout`` total mesh path discovery timeout, in msecs ``discovery_retries`` mesh path discovery retries ``flags`` mesh path flags from :c:type:`enum mesh_path_flags ` ``hop_count`` hops to destination ``path_change_count`` total number of path changes to destination ``generation`` generation number for nl80211 dumps. This number should increase every time the list of mesh paths changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjΦhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjʦubh:}(hjʦhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjƦubj: )}(hstruct mpath_info { u32 filled; u32 frame_qlen; u32 sn; u32 metric; u32 exptime; u32 discovery_timeout; u8 discovery_retries; u8 flags; u8 hop_count; u32 path_change_count; int generation; };h]hstruct mpath_info { u32 filled; u32 frame_qlen; u32 sn; u32 metric; u32 exptime; u32 discovery_timeout; u8 discovery_retries; u8 flags; u8 hop_count; u32 path_change_count; int generation; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j9 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&]uh1jhjubah}(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](j0)}(h ``filled``h]j,)}(hjh]hfilled}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hIbitfield of flags from :c:type:`enum mpath_info_flags `h](hbitfield of flags from }(hj0hhhNhNubh)}(h2:c:type:`enum mpath_info_flags `h]j,)}(hj:h]henum mpath_info_flags}(hj<hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj8ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJmpath_info_flagsuh1hhj,hM hj0ubeh}(h]h ]h"]h$]h&]uh1hhj,hM hj-ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj,hM hjubj*)}(h<``frame_qlen`` number of queued frames for this destination h](j0)}(h``frame_qlen``h]j,)}(hjoh]h frame_qlen}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjmubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjiubjJ)}(hhh]h)}(h,number of queued frames for this destinationh]h,number of queued frames for this destination}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h``sn`` target sequence number h](j0)}(h``sn``h]j,)}(hjh]hsn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(htarget sequence numberh]htarget sequence number}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h+``metric`` metric (cost) of this mesh path h](j0)}(h ``metric``h]j,)}(hjh]hmetric}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjߧubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjۧubjJ)}(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&]uh1jIhjۧubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(hA``exptime`` expiration time for the mesh path from now, in msecs h](j0)}(h ``exptime``h]j,)}(hjh]hexptime}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h4expiration time for the mesh path from now, in msecsh]h4expiration time for the mesh path from now, in msecs}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hM hj0ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj/hM hjubj*)}(hB``discovery_timeout`` total mesh path discovery timeout, in msecs h](j0)}(h``discovery_timeout``h]j,)}(hjSh]hdiscovery_timeout}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjQubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjMubjJ)}(hhh]h)}(h+total mesh path discovery timeout, in msecsh]h+total mesh path discovery timeout, in msecs}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhM hjiubah}(h]h ]h"]h$]h&]uh1jIhjMubeh}(h]h ]h"]h$]h&]uh1j)hjhhM hjubj*)}(h2``discovery_retries`` mesh path discovery retries h](j0)}(h``discovery_retries``h]j,)}(hjh]hdiscovery_retries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hmesh path discovery retriesh]hmesh path discovery retries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(hP``flags`` mesh path flags from :c:type:`enum mesh_path_flags ` h](j0)}(h ``flags``h]j,)}(hjŨh]hflags}(hjǨhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjèubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hEmesh path flags from :c:type:`enum mesh_path_flags `h](hmesh path flags from }(hjިhhhNhNubh)}(h0:c:type:`enum mesh_path_flags `h]j,)}(hjh]henum mesh_path_flags}(hjhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJmesh_path_flagsuh1hhjڨhM hjިubeh}(h]h ]h"]h$]h&]uh1hhjڨhM hjۨubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjڨhM hjubj*)}(h"``hop_count`` hops to destination h](j0)}(h ``hop_count``h]j,)}(hjh]h hop_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hhops to destinationh]hhops to destination}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hM hj3ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj2hM hjubj*)}(hB``path_change_count`` total number of path changes to destination h](j0)}(h``path_change_count``h]j,)}(hjVh]hpath_change_count}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjTubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjPubjJ)}(hhh]h)}(h+total number of path changes to destinationh]h+total number of path changes to destination}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhM hjlubah}(h]h ]h"]h$]h&]uh1jIhjPubeh}(h]h ]h"]h$]h&]uh1j)hjkhM hjubj*)}(h``generation`` generation number for nl80211 dumps. This number should increase every time the list of mesh paths changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.h](j0)}(h``generation``h]j,)}(hjh]h generation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hgeneration number for nl80211 dumps. This number should increase every time the list of mesh paths changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.h]hgeneration number for nl80211 dumps. This number should increase every time the list of mesh paths changes, i.e. when a station is added or removed, so that userspace can tell whether it got a consistent snapshot.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubeh}(h]h ]h"]h$]h&]uh1j$hjƦubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjҩh]h Description}(hjԩhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjЩubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubh)}(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 hjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsbss_parameters (C struct)c.bss_parametershNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hbss_parametersh]j)}(hstruct bss_parametersh](j)}(hjh]hstruct}(hjhhhNhNubah}(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 }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhjhM ubj)}(hbss_parametersh]j)}(hj h]hbss_parameters}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj hhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhM hjhhubj)}(hhh]h)}(hBSS parametersh]hBSS parameters}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjOhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j8structeh"]h$]h&]jj8jjjjjjjjjuh1jwhhhjcchNhNubj)}(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}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubh:}(hjrhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjnubj: )}(hstruct bss_parameters { int link_id; int use_cts_prot; int use_short_preamble; int use_short_slot_time; const u8 *basic_rates; u8 basic_rates_len; int ap_isolate; int ht_opmode; s8 p2p_ctwindow, p2p_opp_ps; };h]hstruct bss_parameters { int link_id; int use_cts_prot; int use_short_preamble; int use_short_slot_time; const u8 *basic_rates; u8 basic_rates_len; int ap_isolate; int ht_opmode; s8 p2p_ctwindow, p2p_opp_ps; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjnubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjnubj%)}(hhh](j*)}(h&``link_id`` link_id or -1 for non-MLD h](j0)}(h ``link_id``h]j,)}(hjh]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hlink_id or -1 for non-MLDh]hlink_id or -1 for non-MLD}(hjتhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjԪhM hjժubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjԪhM hjubj*)}(hU``use_cts_prot`` Whether to use CTS protection (0 = no, 1 = yes, -1 = do not change) h](j0)}(h``use_cts_prot``h]j,)}(hjh]h use_cts_prot}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hCWhether to use CTS protection (0 = no, 1 = yes, -1 = do not change)h]hCWhether to use CTS protection (0 = no, 1 = yes, -1 = do not change)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hM hjubj*)}(hk``use_short_preamble`` Whether the use of short preambles is allowed (0 = no, 1 = yes, -1 = do not change) h](j0)}(h``use_short_preamble``h]j,)}(hj2h]huse_short_preamble}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj0ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj,ubjJ)}(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)}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjHubah}(h]h ]h"]h$]h&]uh1jIhj,ubeh}(h]h ]h"]h$]h&]uh1j)hjGhM hjubj*)}(hl``use_short_slot_time`` Whether the use of short slot time is allowed (0 = no, 1 = yes, -1 = do not change) h](j0)}(h``use_short_slot_time``h]j,)}(hjlh]huse_short_slot_time}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjfubjJ)}(hhh]h)}(hSWhether the use of short slot time is allowed (0 = no, 1 = yes, -1 = do not change)h]hSWhether the use of short slot time is allowed (0 = no, 1 = yes, -1 = do not change)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1jIhjfubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(hJ``basic_rates`` basic rates in IEEE 802.11 format (or NULL for no change) h](j0)}(h``basic_rates``h]j,)}(hjh]h basic_rates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h9basic rates in IEEE 802.11 format (or NULL for no change)h]h9basic rates in IEEE 802.11 format (or NULL for no change)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h*``basic_rates_len`` number of basic rates h](j0)}(h``basic_rates_len``h]j,)}(hjh]hbasic_rates_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjޫubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjګubjJ)}(hhh]h)}(hnumber of basic ratesh]hnumber of basic rates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjګubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(hg``ap_isolate`` do not forward packets between connected stations (0 = no, 1 = yes, -1 = do not change) h](j0)}(h``ap_isolate``h]j,)}(hjh]h ap_isolate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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)}(hj2hhhNhNubah}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj.hM hjubj*)}(hC``ht_opmode`` HT Operation mode (u16 = opmode, -1 = do not change) h](j0)}(h ``ht_opmode``h]j,)}(hjSh]h ht_opmode}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjQubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjMubjJ)}(hhh]h)}(h4HT Operation mode (u16 = opmode, -1 = do not change)h]h4HT Operation mode (u16 = opmode, -1 = do not change)}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjiubah}(h]h ]h"]h$]h&]uh1jIhjMubeh}(h]h ]h"]h$]h&]uh1j)hjhhM hjubj*)}(h0``p2p_ctwindow`` P2P CT Window (-1 = no change) h](j0)}(h``p2p_ctwindow``h]j,)}(hjh]h p2p_ctwindow}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hP2P CT Window (-1 = no change)h]hP2P CT Window (-1 = no change)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h4``p2p_opp_ps`` P2P opportunistic PS (-1 = no change)h](j0)}(h``p2p_opp_ps``h]j,)}(hjƬh]h p2p_opp_ps}(hjȬhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjĬubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h%P2P opportunistic PS (-1 = no change)h]h%P2P opportunistic PS (-1 = no change)}(hj߬hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjܬubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj۬hM hjubeh}(h]h ]h"]h$]h&]uh1j$hjnubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubh)}(h3Used to change BSS parameters (mainly for AP mode).h]h3Used to change BSS parameters (mainly for AP mode).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsieee80211_txq_params (C struct)c.ieee80211_txq_paramshNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hieee80211_txq_paramsh]j)}(hstruct ieee80211_txq_paramsh](j)}(hjh]hstruct}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjChhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjChhhjThM ubj)}(hieee80211_txq_paramsh]j)}(hjAh]hieee80211_txq_params}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubah}(h]h ](jjeh"]h$]h&]jjuh1jhjChhhjThM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj?hhhjThM ubah}(h]j:ah ](jjeh"]h$]h&]jj)jhuh1j|hjThM hj<hhubj)}(hhh]h)}(hTX queue parametersh]hTX queue parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhj<hhhjThM ubeh}(h]h ](j8structeh"]h$]h&]jj8jjjjjjjuh1jwhhhjcchNhNubj)}(hX"**Definition**:: struct ieee80211_txq_params { enum nl80211_ac ac; u16 txop; u16 cwmin; u16 cwmax; u8 aifs; int link_id; }; **Members** ``ac`` AC identifier ``txop`` Maximum burst time in units of 32 usecs, 0 meaning disabled ``cwmin`` Minimum contention window [a value of the form 2^n-1 in the range 1..32767] ``cwmax`` Maximum contention window [a value of the form 2^n-1 in the range 1..32767] ``aifs`` Arbitration interframe space [0..255] ``link_id`` link_id or -1 for non-MLDh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj: )}(hstruct ieee80211_txq_params { enum nl80211_ac ac; u16 txop; u16 cwmin; u16 cwmax; u8 aifs; int link_id; };h]hstruct ieee80211_txq_params { enum nl80211_ac ac; u16 txop; u16 cwmin; u16 cwmax; u8 aifs; int link_id; };}hjƭsbah}(h]h ]h"]h$]h&]jjuh1j9 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&]uh1jhjխubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubj%)}(hhh](j*)}(h``ac`` AC identifier h](j0)}(h``ac``h]j,)}(hjh]hac}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h AC identifierh]h AC identifier}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM hj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hM hjubj*)}(hE``txop`` Maximum burst time in units of 32 usecs, 0 meaning disabled h](j0)}(h``txop``h]j,)}(hj/h]htxop}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj-ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj)ubjJ)}(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}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDhM hjEubah}(h]h ]h"]h$]h&]uh1jIhj)ubeh}(h]h ]h"]h$]h&]uh1j)hjDhM hjubj*)}(hV``cwmin`` Minimum contention window [a value of the form 2^n-1 in the range 1..32767] h](j0)}(h ``cwmin``h]j,)}(hjhh]hcwmin}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjfubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjbubjJ)}(hhh]h)}(hKMinimum contention window [a value of the form 2^n-1 in the range 1..32767]h]hKMinimum contention window [a value of the form 2^n-1 in the range 1..32767]}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj~ubah}(h]h ]h"]h$]h&]uh1jIhjbubeh}(h]h ]h"]h$]h&]uh1j)hj}hM hjubj*)}(hV``cwmax`` Maximum contention window [a value of the form 2^n-1 in the range 1..32767] h](j0)}(h ``cwmax``h]j,)}(hjh]hcwmax}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hKMaximum contention window [a value of the form 2^n-1 in the range 1..32767]h]hKMaximum contention window [a value of the form 2^n-1 in the range 1..32767]}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h/``aifs`` Arbitration interframe space [0..255] h](j0)}(h``aifs``h]j,)}(hjܮh]haifs}(hjޮhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjڮubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj֮ubjJ)}(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&]uh1jIhj֮ubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h%``link_id`` link_id or -1 for non-MLDh](j0)}(h ``link_id``h]j,)}(hjh]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hlink_id or -1 for non-MLDh]hlink_id or -1 for non-MLD}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj+ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj*hM hjubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js cfg80211_auth_request (C struct)c.cfg80211_auth_requesthNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hcfg80211_auth_requesth]j)}(hstruct cfg80211_auth_requesth](j)}(hjh]hstruct}(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkhhh`/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&]uh1jhjkhhhj|hM ubj)}(hcfg80211_auth_requesth]j)}(hjih]hcfg80211_auth_request}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjkhhhj|hM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjghhhj|hM ubah}(h]jbah ](jjeh"]h$]h&]jj)jhuh1j|hj|hM hjdhhubj)}(hhh]h)}(hAuthentication request datah]hAuthentication request data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjdhhhj|hM ubeh}(h]h ](j8structeh"]h$]h&]jj8jjɯjjɯjjjuh1jwhhhjcchNhNubj)}(hX**Definition**:: struct cfg80211_auth_request { struct cfg80211_bss *bss; const u8 *ie; size_t ie_len; const u8 *supported_selectors; u8 supported_selectors_len; enum nl80211_auth_type auth_type; const u8 *key; u8 key_len; s8 key_idx; const u8 *auth_data; size_t auth_data_len; s8 link_id; const u8 *ap_mld_addr; }; **Members** ``bss`` The BSS to authenticate with, the callee must obtain a reference to it if it needs to keep it. ``ie`` Extra IEs to add to Authentication frame or ``NULL`` ``ie_len`` Length of ie buffer in octets ``supported_selectors`` List of selectors that should be assumed to be supported by the station. SAE_H2E must be assumed supported if set to ``NULL``. ``supported_selectors_len`` Length of supported_selectors in octets. ``auth_type`` Authentication type (algorithm) ``key`` WEP key for shared key authentication ``key_len`` length of WEP key for shared key authentication ``key_idx`` index of WEP key for shared key authentication ``auth_data`` Fields and elements in Authentication frames. This contains the authentication frame body (non-IE and IE data), excluding the Authentication algorithm number, i.e., starting at the Authentication transaction sequence number field. ``auth_data_len`` Length of auth_data buffer in octets ``link_id`` if >= 0, indicates authentication should be done as an MLD, the interface address is included as the MLD address and the necessary link (with the given link_id) will be created (and given an MLD address) by the driver ``ap_mld_addr`` AP MLD address in case of authentication request with an AP MLD, valid iff **link_id** >= 0h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjկhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjѯ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: )}(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&]jjuh1j9 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&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjͯubj%)}(hhh](j*)}(hg``bss`` The BSS to authenticate with, the callee must obtain a reference to it if it needs to keep it. h](j0)}(h``bss``h]j,)}(hjh]hbss}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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.}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj4ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj3hM hjubj*)}(h<``ie`` Extra IEs to add to Authentication frame or ``NULL`` h](j0)}(h``ie``h]j,)}(hjXh]hie}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjVubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjRubjJ)}(hhh]h)}(h4Extra IEs to add to Authentication frame or ``NULL``h](h,Extra IEs to add to Authentication frame or }(hjqhhhNhNubj,)}(h``NULL``h]hNULL}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjqubeh}(h]h ]h"]h$]h&]uh1hhjmhM hjnubah}(h]h ]h"]h$]h&]uh1jIhjRubeh}(h]h ]h"]h$]h&]uh1j)hjmhM hjubj*)}(h)``ie_len`` Length of ie buffer in octets h](j0)}(h ``ie_len``h]j,)}(hjh]hie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h``supported_selectors`` List of selectors that should be assumed to be supported by the station. SAE_H2E must be assumed supported if set to ``NULL``. h](j0)}(h``supported_selectors``h]j,)}(hjذh]hsupported_selectors}(hjڰhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjְubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjҰubjJ)}(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&]uh1j+hjubh.}(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&]uh1jIhjҰubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(hE``supported_selectors_len`` Length of supported_selectors in octets. h](j0)}(h``supported_selectors_len``h]j,)}(hj$h]hsupported_selectors_len}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj"ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h(Length of supported_selectors in octets.h]h(Length of supported_selectors in octets.}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hM hj:ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj9hM hjubj*)}(h.``auth_type`` Authentication type (algorithm) h](j0)}(h ``auth_type``h]j,)}(hj]h]h auth_type}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj[ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjWubjJ)}(hhh]h)}(hAuthentication type (algorithm)h]hAuthentication type (algorithm)}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrhM hjsubah}(h]h ]h"]h$]h&]uh1jIhjWubeh}(h]h ]h"]h$]h&]uh1j)hjrhM hjubj*)}(h.``key`` WEP key for shared key authentication h](j0)}(h``key``h]j,)}(hjh]hkey}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h%WEP key for shared key authenticationh]h%WEP key for shared key authentication}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h<``key_len`` length of WEP key for shared key authentication h](j0)}(h ``key_len``h]j,)}(hjϱh]hkey_len}(hjѱhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjͱubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjɱubjJ)}(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&]uh1jIhjɱubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h;``key_idx`` index of WEP key for shared key authentication h](j0)}(h ``key_idx``h]j,)}(hjh]hkey_idx}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h``auth_data`` Fields and elements in Authentication frames. This contains the authentication frame body (non-IE and IE data), excluding the Authentication algorithm number, i.e., starting at the Authentication transaction sequence number field. h](j0)}(h ``auth_data``h]j,)}(hjAh]h auth_data}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj?ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj;ubjJ)}(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.}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjWubah}(h]h ]h"]h$]h&]uh1jIhj;ubeh}(h]h ]h"]h$]h&]uh1j)hjVhM hjubj*)}(h7``auth_data_len`` Length of auth_data buffer in octets h](j0)}(h``auth_data_len``h]j,)}(hj{h]h auth_data_len}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjyubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjuubjJ)}(hhh]h)}(h$Length of auth_data buffer in octetsh]h$Length of auth_data buffer in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjuubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h``link_id`` if >= 0, indicates authentication should be done as an MLD, the interface address is included as the MLD address and the necessary link (with the given link_id) will be created (and given an MLD address) by the driver h](j0)}(h ``link_id``h]j,)}(hjh]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hif >= 0, indicates authentication should be done as an MLD, the interface address is included as the MLD address and the necessary link (with the given link_id) will be created (and given an MLD address) by the driverh]hif >= 0, indicates authentication should be done as an MLD, the interface address is included as the MLD address and the necessary link (with the given link_id) will be created (and given an MLD address) by the driver}(hjͲhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjʲubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjɲhM hjubj*)}(hk``ap_mld_addr`` AP MLD address in case of authentication request with an AP MLD, valid iff **link_id** >= 0h](j0)}(h``ap_mld_addr``h]j,)}(hjh]h ap_mld_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h[AP MLD address in case of authentication request with an AP MLD, valid iff **link_id** >= 0h](hKAP MLD address in case of authentication request with an AP MLD, valid iff }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh >= 0}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubeh}(h]h ]h"]h$]h&]uh1j$hjͯubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjBh]h Description}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubh)}(hRThis structure provides information needed to complete IEEE 802.11 authentication.h]hRThis structure provides information needed to complete IEEE 802.11 authentication.}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js!cfg80211_assoc_request (C struct)c.cfg80211_assoc_requesthNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hcfg80211_assoc_requesth]j)}(hstruct cfg80211_assoc_requesth](j)}(hjh]hstruct}(hjhhhNhNubah}(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 }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj|hhhjhM ubj)}(hcfg80211_assoc_requesth]j)}(hjzh]hcfg80211_assoc_request}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhj|hhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjxhhhjhM ubah}(h]jsah ](jjeh"]h$]h&]jj)jhuh1j|hjhM hjuhhubj)}(hhh]h)}(h(Re)Association request datah]h(Re)Association 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 hjhhubah}(h]h ]h"]h$]h&]uh1jhjuhhhjhM ubeh}(h]h ](j8structeh"]h$]h&]jj8jjڳjjڳjjjuh1jwhhhjcchNhNubj)}(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&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj޳ubj: )}(hXstruct cfg80211_assoc_request { struct cfg80211_bss *bss; const u8 *ie, *prev_bssid; size_t ie_len; struct cfg80211_crypto_settings crypto; bool use_mfp; u32 flags; const u8 *supported_selectors; u8 supported_selectors_len; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct ieee80211_vht_cap vht_capa, vht_capa_mask; const u8 *fils_kek; size_t fils_kek_len; const u8 *fils_nonces; struct ieee80211_s1g_cap s1g_capa, s1g_capa_mask; struct cfg80211_assoc_link links[IEEE80211_MLD_MAX_NUM_LINKS]; const u8 *ap_mld_addr; s8 link_id; u16 ext_mld_capa_ops; };h]hXstruct cfg80211_assoc_request { struct cfg80211_bss *bss; const u8 *ie, *prev_bssid; size_t ie_len; struct cfg80211_crypto_settings crypto; bool use_mfp; u32 flags; const u8 *supported_selectors; u8 supported_selectors_len; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct ieee80211_vht_cap vht_capa, vht_capa_mask; const u8 *fils_kek; size_t fils_kek_len; const u8 *fils_nonces; struct ieee80211_s1g_cap s1g_capa, s1g_capa_mask; struct cfg80211_assoc_link links[IEEE80211_MLD_MAX_NUM_LINKS]; const u8 *ap_mld_addr; s8 link_id; u16 ext_mld_capa_ops; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j9 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&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM' hj޳ubj%)}(hhh](j*)}(hX``bss`` The BSS to associate with. If the call is successful the driver is given a reference that it must give back to cfg80211_send_rx_assoc() or to cfg80211_assoc_timeout(). To ensure proper refcounting, new association requests while already associating must be rejected. This also applies to the **links.bss** parameter, which is used instead of this one (it is ``NULL``) for MLO associations. h](j0)}(h``bss``h]j,)}(hj/h]hbss}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj-ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj)ubjJ)}(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 }(hjHhhhNhNubj)}(h **links.bss**h]h links.bss}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubh5 parameter, which is used instead of this one (it is }(hjHhhhNhNubj,)}(h``NULL``h]hNULL}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjHubh) for MLO associations.}(hjHhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjEubah}(h]h ]h"]h$]h&]uh1jIhj)ubeh}(h]h ]h"]h$]h&]uh1j)hjDhM hj&ubj*)}(hE``ie`` Extra IEs to add to (Re)Association Request frame or ``NULL`` h](j0)}(h``ie``h]j,)}(hjh]hie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h=Extra IEs to add to (Re)Association Request frame or ``NULL``h](h5Extra IEs to add to (Re)Association Request frame or }(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM 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](j0)}(h``prev_bssid``h]j,)}(hjԴh]h prev_bssid}(hjִhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjҴubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjδubjJ)}(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&]uh1j+hjubhXB 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&]uh1jIhjδubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj&ubj*)}(h)``ie_len`` Length of ie buffer in octets h](j0)}(h ``ie_len``h]j,)}(hj h]hie_len}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hM hj6ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj5hM hj&ubj*)}(h``crypto`` crypto settings h](j0)}(h ``crypto``h]j,)}(hjYh]hcrypto}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjWubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjSubjJ)}(hhh]h)}(hcrypto settingsh]hcrypto settings}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhM hjoubah}(h]h ]h"]h$]h&]uh1jIhjSubeh}(h]h ]h"]h$]h&]uh1j)hjnhM hj&ubj*)}(hO``use_mfp`` Use management frame protection (IEEE 802.11w) in this association h](j0)}(h ``use_mfp``h]j,)}(hjh]huse_mfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hBUse management frame protection (IEEE 802.11w) in this associationh]hBUse management frame protection (IEEE 802.11w) in this association}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj&ubj*)}(hQ``flags`` See :c:type:`enum cfg80211_assoc_req_flags ` h](j0)}(h ``flags``h]j,)}(hj˵h]hflags}(hj͵hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjɵubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjŵubjJ)}(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 ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJcfg80211_assoc_req_flagsuh1hhjhM hjubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjŵubeh}(h]h ]h"]h$]h&]uh1j)hjhM 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](j0)}(h``supported_selectors``h]j,)}(hj#h]hsupported_selectors}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj!ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM# hjubjJ)}(hhh]h)}(hsupported BSS selectors in IEEE 802.11 format (or ``NULL`` for no change). If ``NULL``, then support for SAE_H2E should be assumed.h](h2supported BSS selectors in IEEE 802.11 format (or }(hj<hhhNhNubj,)}(h``NULL``h]hNULL}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj<ubh for no change). If }(hj<hhhNhNubj,)}(h``NULL``h]hNULL}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj<ubh-, then support for SAE_H2E should be assumed.}(hj<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM! hj9ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj8hM# hj&ubj*)}(h>``supported_selectors_len`` number of supported BSS selectors h](j0)}(h``supported_selectors_len``h]j,)}(hjh]hsupported_selectors_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$ hj{ubjJ)}(hhh]h)}(h!number of supported BSS selectorsh]h!number of supported BSS selectors}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM$ hjubah}(h]h ]h"]h$]h&]uh1jIhj{ubeh}(h]h ]h"]h$]h&]uh1j)hjhM$ 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](j0)}(h ``ht_capa``h]j,)}(hjh]hht_capa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM& hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj϶hM& hj&ubj*)}(h;``ht_capa_mask`` The bits of ht_capa which are to be used. h](j0)}(h``ht_capa_mask``h]j,)}(hjh]h ht_capa_mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM' hjubjJ)}(hhh]h)}(h)The bits of ht_capa which are to be used.h]h)The bits of ht_capa which are to be used.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM' hj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hM' hj&ubj*)}(h%``vht_capa`` VHT capability override h](j0)}(h ``vht_capa``h]j,)}(hj-h]hvht_capa}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj+ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM( hj'ubjJ)}(hhh]h)}(hVHT capability overrideh]hVHT capability override}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhM( hjCubah}(h]h ]h"]h$]h&]uh1jIhj'ubeh}(h]h ]h"]h$]h&]uh1j)hjBhM( hj&ubj*)}(hE``vht_capa_mask`` VHT capability mask indicating which fields to use h](j0)}(h``vht_capa_mask``h]j,)}(hjfh]h vht_capa_mask}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjdubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM) hj`ubjJ)}(hhh]h)}(h2VHT capability mask indicating which fields to useh]h2VHT capability mask indicating which fields to use}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hM) hj|ubah}(h]h ]h"]h$]h&]uh1jIhj`ubeh}(h]h ]h"]h$]h&]uh1j)hj{hM) hj&ubj*)}(hm``fils_kek`` FILS KEK for protecting (Re)Association Request/Response frame or ``NULL`` if FILS is not used. h](j0)}(h ``fils_kek``h]j,)}(hjh]hfils_kek}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM+ hjubjJ)}(hhh]h)}(h_FILS KEK for protecting (Re)Association Request/Response frame or ``NULL`` if FILS is not used.h](hBFILS KEK for protecting (Re)Association Request/Response frame or }(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh if FILS is not used.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM* hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM+ hj&ubj*)}(h.``fils_kek_len`` Length of fils_kek in octets h](j0)}(h``fils_kek_len``h]j,)}(hjh]h fils_kek_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM, hjubjJ)}(hhh]h)}(hLength of fils_kek in octetsh]hLength of fils_kek in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM, hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM, 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](j0)}(h``fils_nonces``h]j,)}(hj$h]h fils_nonces}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj"ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM/ hjubjJ)}(hhh]h)}(hFILS nonces (part of AAD) for protecting (Re)Association Request/Response frame or ``NULL`` if FILS is not used. This field starts with 16 octets of STA Nonce followed by 16 octets of AP Nonce.h](hSFILS nonces (part of AAD) for protecting (Re)Association Request/Response frame or }(hj=hhhNhNubj,)}(h``NULL``h]hNULL}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj=ubhf if FILS is not used. This field starts with 16 octets of STA Nonce followed by 16 octets of AP Nonce.}(hj=hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM- hj:ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj9hM/ hj&ubj*)}(h%``s1g_capa`` S1G capability override h](j0)}(h ``s1g_capa``h]j,)}(hjph]hs1g_capa}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjnubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM0 hjjubjJ)}(hhh]h)}(hS1G capability overrideh]hS1G capability override}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM0 hjubah}(h]h ]h"]h$]h&]uh1jIhjjubeh}(h]h ]h"]h$]h&]uh1j)hjhM0 hj&ubj*)}(h/``s1g_capa_mask`` S1G capability override mask h](j0)}(h``s1g_capa_mask``h]j,)}(hjh]h s1g_capa_mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM1 hjubjJ)}(hhh]h)}(hS1G capability override maskh]hS1G capability override mask}(hj¸hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM1 hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM1 hj&ubj*)}(h3``links`` per-link information for MLO connections h](j0)}(h ``links``h]j,)}(hjh]hlinks}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM2 hjܸubjJ)}(hhh]h)}(h(per-link information for MLO connectionsh]h(per-link information for MLO connections}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM2 hjubah}(h]h ]h"]h$]h&]uh1jIhjܸubeh}(h]h ]h"]h$]h&]uh1j)hjhM2 hj&ubj*)}(h^``ap_mld_addr`` AP MLD address in case of MLO association request, valid iff **link_id** >= 0 h](j0)}(h``ap_mld_addr``h]j,)}(hjh]h ap_mld_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM6 hjubjJ)}(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 }(hj4hhhNhNubj)}(h **link_id**h]hlink_id}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubh >= 0}(hj4hhhNhNubeh}(h]h ]hh"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM5 hj1ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj0hM6 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](j0)}(h ``link_id``h]j,)}(hjgh]hlink_id}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjeubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM4 hjaubjJ)}(hhh]h)}(hw>= 0 for MLO connections, where links are given, and indicates the link on which the association request should be senth]hw>= 0 for MLO connections, where links are given, and indicates the link on which the association request should be sent}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM3 hj}ubah}(h]h ]h"]h$]h&]uh1jIhjaubeh}(h]h ]h"]h$]h&]uh1j)hj|hM4 hj&ubj*)}(hb``ext_mld_capa_ops`` extended MLD capabilities and operations set by userspace for the associationh](j0)}(h``ext_mld_capa_ops``h]j,)}(hjh]hext_mld_capa_ops}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM7 hjubjJ)}(hhh]h)}(hMextended MLD capabilities and operations set by userspace for the associationh]hMextended MLD capabilities and operations set by userspace for the association}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM7 hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM7 hj&ubeh}(h]h ]h"]h$]h&]uh1j$hj޳ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM; hjcchhubh)}(hSThis structure provides information needed to complete IEEE 802.11 (re)association.h]hSThis structure provides information needed to complete IEEE 802.11 (re)association.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js"cfg80211_deauth_request (C struct)c.cfg80211_deauth_requesthNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hcfg80211_deauth_requesth]j)}(hstruct cfg80211_deauth_requesth](j)}(hjh]hstruct}(hj!hhhNhNubah}(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_deauth_requesth]j)}(hjh]hcfg80211_deauth_request}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhj.hM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhj.hM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hj.hM hjhhubj)}(hhh]h)}(hDeauthentication request datah]hDeauthentication request data}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMP hj`hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj.hM ubeh}(h]h ](j8structeh"]h$]h&]jj8jj{jj{jjjuh1jwhhhjcchNhNubj)}(hX**Definition**:: struct cfg80211_deauth_request { const u8 *bssid; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; }; **Members** ``bssid`` the BSSID or AP MLD address to deauthenticate from ``ie`` Extra IEs to add to Deauthentication frame or ``NULL`` ``ie_len`` Length of ie buffer in octets ``reason_code`` The reason code for the deauthentication ``local_state_change`` if set, change local state only and do not set a deauth frameh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMT hjubj: )}(hstruct cfg80211_deauth_request { const u8 *bssid; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; };h]hstruct cfg80211_deauth_request { const u8 *bssid; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMV hjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^ hjubj%)}(hhh](j*)}(h=``bssid`` the BSSID or AP MLD address to deauthenticate from h](j0)}(h ``bssid``h]j,)}(hjкh]hbssid}(hjҺhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjκubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMV hjʺubjJ)}(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&]uh1hhjhMV hjubah}(h]h ]h"]h$]h&]uh1jIhjʺubeh}(h]h ]h"]h$]h&]uh1j)hjhMV hjǺubj*)}(h>``ie`` Extra IEs to add to Deauthentication frame or ``NULL`` h](j0)}(h``ie``h]j,)}(hj h]hie}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMW hjubjJ)}(hhh]h)}(h6Extra IEs to add to Deauthentication frame or ``NULL``h](h.Extra IEs to add to Deauthentication frame or }(hj"hhhNhNubj,)}(h``NULL``h]hNULL}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj"ubeh}(h]h ]h"]h$]h&]uh1hhjhMW hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMW hjǺubj*)}(h)``ie_len`` Length of ie buffer in octets h](j0)}(h ``ie_len``h]j,)}(hjPh]hie_len}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjNubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMX hjJubjJ)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMX hjfubah}(h]h ]h"]h$]h&]uh1jIhjJubeh}(h]h ]h"]h$]h&]uh1j)hjehMX hjǺubj*)}(h9``reason_code`` The reason code for the deauthentication h](j0)}(h``reason_code``h]j,)}(hjh]h reason_code}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMY hjubjJ)}(hhh]h)}(h(The reason code for the deauthenticationh]h(The reason code for the deauthentication}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMY hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMY hjǺubj*)}(hT``local_state_change`` if set, change local state only and do not set a deauth frameh](j0)}(h``local_state_change``h]j,)}(hj»h]hlocal_state_change}(hjĻhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMZ hjubjJ)}(hhh]h)}(h=if set, change local state only and do not set a deauth frameh]h=if set, change local state only and do not set a deauth frame}(hjۻhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj׻hMZ hjػubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj׻hMZ hjǺubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^ hjcchhubh)}(hTThis structure provides information needed to complete IEEE 802.11 deauthentication.h]hTThis structure provides information needed to complete IEEE 802.11 deauthentication.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMQ hjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js$cfg80211_disassoc_request (C struct)c.cfg80211_disassoc_requesthNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hcfg80211_disassoc_requesth]j)}(h struct cfg80211_disassoc_requesth](j)}(hjh]hstruct}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMW ubj)}(h h]h }(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>hhhjOhMW ubj)}(hcfg80211_disassoc_requesth]j)}(hj<h]hcfg80211_disassoc_request}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj>hhhjOhMW ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj:hhhjOhMW ubah}(h]j5ah ](jjeh"]h$]h&]jj)jhuh1j|hjOhMW hj7hhubj)}(hhh]h)}(hDisassociation request datah]hDisassociation request data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMe hjhhubah}(h]h ]h"]h$]h&]uh1jhj7hhhjOhMW ubeh}(h]h ](j8structeh"]h$]h&]jj8jjjjjjjuh1jwhhhjcchNhNubj)}(hX**Definition**:: struct cfg80211_disassoc_request { const u8 *ap_addr; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; }; **Members** ``ap_addr`` the BSSID or AP MLD address to disassociate from ``ie`` Extra IEs to add to Disassociation frame or ``NULL`` ``ie_len`` Length of ie buffer in octets ``reason_code`` The reason code for the disassociation ``local_state_change`` This is a request for a local state only, i.e., no Disassociation frame is to be transmitted.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMi hjubj: )}(hstruct cfg80211_disassoc_request { const u8 *ap_addr; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; };h]hstruct cfg80211_disassoc_request { const u8 *ap_addr; const u8 *ie; size_t ie_len; u16 reason_code; bool local_state_change; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j9 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&]uh1jhjмubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMs hjubj%)}(hhh](j*)}(h=``ap_addr`` the BSSID or AP MLD address to disassociate from h](j0)}(h ``ap_addr``h]j,)}(hjh]hap_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMk hjubjJ)}(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&]uh1hhjhMk hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMk hjubj*)}(h<``ie`` Extra IEs to add to Disassociation frame or ``NULL`` h](j0)}(h``ie``h]j,)}(hj*h]hie}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj(ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMl hj$ubjJ)}(hhh]h)}(h4Extra IEs to add to Disassociation frame or ``NULL``h](h,Extra IEs to add to Disassociation frame or }(hjChhhNhNubj,)}(h``NULL``h]hNULL}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjCubeh}(h]h ]h"]h$]h&]uh1hhj?hMl hj@ubah}(h]h ]h"]h$]h&]uh1jIhj$ubeh}(h]h ]h"]h$]h&]uh1j)hj?hMl hjubj*)}(h)``ie_len`` Length of ie buffer in octets h](j0)}(h ``ie_len``h]j,)}(hjqh]hie_len}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjoubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMm hjkubjJ)}(hhh]h)}(hLength of ie buffer in octetsh]hLength of ie buffer in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMm hjubah}(h]h ]h"]h$]h&]uh1jIhjkubeh}(h]h ]h"]h$]h&]uh1j)hjhMm hjubj*)}(h7``reason_code`` The reason code for the disassociation h](j0)}(h``reason_code``h]j,)}(hjh]h reason_code}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMn hjubjJ)}(hhh]h)}(h&The reason code for the disassociationh]h&The reason code for the disassociation}(hjýhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMn hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMn hjubj*)}(ht``local_state_change`` This is a request for a local state only, i.e., no Disassociation frame is to be transmitted.h](j0)}(h``local_state_change``h]j,)}(hjh]hlocal_state_change}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMo hjݽubjJ)}(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&]uh1hhjhMo hjubah}(h]h ]h"]h$]h&]uh1jIhjݽubeh}(h]h ]h"]h$]h&]uh1j)hjhMo hjubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hj%h]h Description}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMs hjcchhubh)}(hRThis structure provides information needed to complete IEEE 802.11 disassociation.h]hRThis structure provides information needed to complete IEEE 802.11 disassociation.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMf hjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jscfg80211_ibss_params (C struct)c.cfg80211_ibss_paramshNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hcfg80211_ibss_paramsh]j)}(hstruct cfg80211_ibss_paramsh](j)}(hjh]hstruct}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMl ubj)}(h h]h }(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_hhhjphMl ubj)}(hcfg80211_ibss_paramsh]j)}(hj]h]hcfg80211_ibss_params}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhj_hhhjphMl ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj[hhhjphMl ubah}(h]jVah ](jjeh"]h$]h&]jj)jhuh1j|hjphMl hjXhhubj)}(hhh]h)}(hIBSS parametersh]hIBSS parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMz hjhhubah}(h]h ]h"]h$]h&]uh1jhjXhhhjphMl ubeh}(h]h ](j8structeh"]h$]h&]jj8jjjjjjjuh1jwhhhjcchNhNubj)}(hX**Definition**:: struct cfg80211_ibss_params { const u8 *ssid; const u8 *bssid; struct cfg80211_chan_def chandef; const u8 *ie; u8 ssid_len, ie_len; u16 beacon_interval; u32 basic_rates; bool channel_fixed; bool privacy; bool control_port; bool control_port_over_nl80211; bool userspace_handles_dfs; int mcast_rate[NUM_NL80211_BANDS]; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct key_params *wep_keys; int wep_tx_key; }; **Members** ``ssid`` The SSID, will always be non-null. ``bssid`` Fixed BSSID requested, maybe be ``NULL``, if set do not search for IBSSs with a different BSSID. ``chandef`` defines the channel to use if no other IBSS to join can be found ``ie`` information element(s) to include in the beacon ``ssid_len`` The length of the SSID, will always be non-zero. ``ie_len`` length of that ``beacon_interval`` beacon interval to use ``basic_rates`` bitmap of basic rates to use when creating the IBSS ``channel_fixed`` The channel should be fixed -- do not search for IBSSs to join on other channels. ``privacy`` this is a protected network, keys will be configured after joining ``control_port`` whether user space controls IEEE 802.1X port, i.e., sets/clears ``NL80211_STA_FLAG_AUTHORIZED``. If true, the driver is required to assume that the port is unauthorized until authorized by user space. Otherwise, port is marked authorized by default. ``control_port_over_nl80211`` TRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface. ``userspace_handles_dfs`` whether user space controls DFS operation, i.e. changes the channel when a radar is detected. This is required to operate on DFS channels. ``mcast_rate`` per-band multicast rate index + 1 (0: disabled) ``ht_capa`` HT Capabilities over-rides. Values set in ht_capa_mask will be used in ht_capa. Un-supported values will be ignored. ``ht_capa_mask`` The bits of ht_capa which are to be used. ``wep_keys`` static WEP keys, if not NULL points to an array of CFG80211_MAX_WEP_KEYS WEP keys ``wep_tx_key`` key index (0..3) of the default TX static WEP keyh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjɾhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjžubh:}(hjžhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM~ hjubj: )}(hXstruct cfg80211_ibss_params { const u8 *ssid; const u8 *bssid; struct cfg80211_chan_def chandef; const u8 *ie; u8 ssid_len, ie_len; u16 beacon_interval; u32 basic_rates; bool channel_fixed; bool privacy; bool control_port; bool control_port_over_nl80211; bool userspace_handles_dfs; int mcast_rate[NUM_NL80211_BANDS]; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct key_params *wep_keys; int wep_tx_key; };h]hXstruct cfg80211_ibss_params { const u8 *ssid; const u8 *bssid; struct cfg80211_chan_def chandef; const u8 *ie; u8 ssid_len, ie_len; u16 beacon_interval; u32 basic_rates; bool channel_fixed; bool privacy; bool control_port; bool control_port_over_nl80211; bool userspace_handles_dfs; int mcast_rate[NUM_NL80211_BANDS]; struct ieee80211_ht_cap ht_capa; struct ieee80211_ht_cap ht_capa_mask; struct key_params *wep_keys; int wep_tx_key; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j9 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&]uh1jhjubah}(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,``ssid`` The SSID, will always be non-null. h](j0)}(h``ssid``h]j,)}(hjh]hssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj ubjJ)}(hhh]h)}(h"The SSID, will always be non-null.h]h"The SSID, will always be non-null.}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hM hj(ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj'hM hj ubj*)}(hk``bssid`` Fixed BSSID requested, maybe be ``NULL``, if set do not search for IBSSs with a different BSSID. h](j0)}(h ``bssid``h]j,)}(hjKh]hbssid}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjIubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjEubjJ)}(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 }(hjdhhhNhNubj,)}(h``NULL``h]hNULL}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjdubh8, if set do not search for IBSSs with a different BSSID.}(hjdhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjaubah}(h]h ]h"]h$]h&]uh1jIhjEubeh}(h]h ]h"]h$]h&]uh1j)hj`hM hj ubj*)}(hM``chandef`` defines the channel to use if no other IBSS to join can be found h](j0)}(h ``chandef``h]j,)}(hjh]hchandef}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h@defines the channel to use if no other IBSS to join can be foundh]h@defines the channel to use if no other IBSS to join can be found}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj ubj*)}(h7``ie`` information element(s) to include in the beacon h](j0)}(h``ie``h]j,)}(hjпh]hie}(hjҿhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjοubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjʿubjJ)}(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&]uh1jIhjʿubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj ubj*)}(h>``ssid_len`` The length of the SSID, will always be non-zero. h](j0)}(h ``ssid_len``h]j,)}(hj h]hssid_len}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj ubj*)}(h``ie_len`` length of that h](j0)}(h ``ie_len``h]j,)}(hjBh]hie_len}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj@ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj<ubjJ)}(hhh]h)}(hlength of thath]hlength of that}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhM hjXubah}(h]h ]h"]h$]h&]uh1jIhj<ubeh}(h]h ]h"]h$]h&]uh1j)hjWhM hj ubj*)}(h+``beacon_interval`` beacon interval to use h](j0)}(h``beacon_interval``h]j,)}(hj{h]hbeacon_interval}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjyubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjuubjJ)}(hhh]h)}(hbeacon interval to useh]hbeacon interval to use}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjuubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj ubj*)}(hD``basic_rates`` bitmap of basic rates to use when creating the IBSS h](j0)}(h``basic_rates``h]j,)}(hjh]h basic_rates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj ubj*)}(hd``channel_fixed`` The channel should be fixed -- do not search for IBSSs to join on other channels. h](j0)}(h``channel_fixed``h]j,)}(hjh]h channel_fixed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj ubj*)}(hO``privacy`` this is a protected network, keys will be configured after joining h](j0)}(h ``privacy``h]j,)}(hj'h]hprivacy}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj%ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj!ubjJ)}(hhh]h)}(hBthis is a protected network, keys will be configured after joiningh]hBthis is a protected network, keys will be configured after joining}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj=ubah}(h]h ]h"]h$]h&]uh1jIhj!ubeh}(h]h ]h"]h$]h&]uh1j)hj<hM hj ubj*)}(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](j0)}(h``control_port``h]j,)}(hjah]h control_port}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj_ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj[ubjJ)}(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 }(hjzhhhNhNubj,)}(h``NL80211_STA_FLAG_AUTHORIZED``h]hNL80211_STA_FLAG_AUTHORIZED}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjzubh. 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.}(hjzhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjwubah}(h]h ]h"]h$]h&]uh1jIhj[ubeh}(h]h ]h"]h$]h&]uh1j)hjvhM hj ubj*)}(h``control_port_over_nl80211`` TRUE if userspace expects to exchange control port frames over NL80211 instead of the network interface. h](j0)}(h``control_port_over_nl80211``h]j,)}(hjh]hcontrol_port_over_nl80211}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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.}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj ubj*)}(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](j0)}(h``userspace_handles_dfs``h]j,)}(hjh]huserspace_handles_dfs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj ubj*)}(h?``mcast_rate`` per-band multicast rate index + 1 (0: disabled) h](j0)}(h``mcast_rate``h]j,)}(hj!h]h mcast_rate}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h/per-band multicast rate index + 1 (0: disabled)h]h/per-band multicast rate index + 1 (0: disabled)}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM hj7ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj6hM 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](j0)}(h ``ht_capa``h]j,)}(hjZh]hht_capa}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjXubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjTubjJ)}(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.}(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&]uh1jIhjTubeh}(h]h ]h"]h$]h&]uh1j)hjohM hj ubj*)}(h;``ht_capa_mask`` The bits of ht_capa which are to be used. h](j0)}(h``ht_capa_mask``h]j,)}(hjh]h ht_capa_mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj ubj*)}(h_``wep_keys`` static WEP keys, if not NULL points to an array of CFG80211_MAX_WEP_KEYS WEP keys h](j0)}(h ``wep_keys``h]j,)}(hjh]hwep_keys}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj ubj*)}(h@``wep_tx_key`` key index (0..3) of the default TX static WEP keyh](j0)}(h``wep_tx_key``h]j,)}(hjh]h wep_tx_key}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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 hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj ubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjJh]h Description}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubh)}(hFThis structure defines the IBSS parameters for the join_ibss() method.h]hFThis structure defines the IBSS parameters for the join_ibss() method.}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM{ hjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js"cfg80211_connect_params (C struct)c.cfg80211_connect_paramshNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hcfg80211_connect_paramsh]j)}(hstruct cfg80211_connect_paramsh](j)}(hjh]hstruct}(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_paramsh]j)}(hjh]hcfg80211_connect_params}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM ubah}(h]j{ah ](jjeh"]h$]h&]jj)jhuh1j|hjhM hj}hhubj)}(hhh]h)}(hConnection parametersh]hConnection parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhj}hhhjhM ubeh}(h]h ](j8structeh"]h$]h&]jj8jjjjjjjuh1jwhhhjcchNhNubj)}(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&]uh1jhjubh:}(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&]jjuh1j9 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&]uh1jhjubah}(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](j0)}(h ``channel``h]j,)}(hj7h]hchannel}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj5ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj1ubjJ)}(hhh]h)}(hSThe channel to use or ``NULL`` if not specified (auto-select based on scan results)h](hThe channel to use or }(hjPhhhNhNubj,)}(h``NULL``h]hNULL}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjPubh5 if not specified (auto-select based on scan results)}(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&]uh1jIhj1ubeh}(h]h ]h"]h$]h&]uh1j)hjLhM hj.ubj*)}(hh``channel_hint`` The channel of the recommended BSS for initial connection or ``NULL`` if not specified h](j0)}(h``channel_hint``h]j,)}(hjh]h channel_hint}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj}ubjJ)}(hhh]h)}(hVThe channel of the recommended BSS for initial connection or ``NULL`` if not specifiedh](h=The channel of the recommended BSS for initial connection or }(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh if not specified}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1jIhj}ubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(hX``bssid`` The AP BSSID or ``NULL`` if not specified (auto-select based on scan results) h](j0)}(h ``bssid``h]j,)}(hjh]hbssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1j+hjubh5 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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h``bssid_hint`` The recommended AP BSSID for initial connection to the BSS or ``NULL`` if not specified. Unlike the **bssid** parameter, the driver is allowed to ignore this **bssid_hint** if it has knowledge of a better BSS to use. h](j0)}(h``bssid_hint``h]j,)}(hjh]h bssid_hint}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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 }(hj4hhhNhNubj,)}(h``NULL``h]hNULL}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj4ubh if not specified. Unlike the }(hj4hhhNhNubj)}(h **bssid**h]hbssid}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubh1 parameter, the driver is allowed to ignore this }(hj4hhhNhNubj)}(h**bssid_hint**h]h bssid_hint}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubh, if it has knowledge of a better BSS to use.}(hj4hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj1ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj0hM hj.ubj*)}(h``ssid`` SSID h](j0)}(h``ssid``h]j,)}(hjh]hssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hSSIDh]hSSID}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h&``ssid_len`` Length of ssid in octets h](j0)}(h ``ssid_len``h]j,)}(hjh]hssid_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h.``auth_type`` Authentication type (algorithm) h](j0)}(h ``auth_type``h]j,)}(hjh]h auth_type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hAuthentication type (algorithm)h]hAuthentication type (algorithm)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h#``ie`` IEs for association request h](j0)}(h``ie``h]j,)}(hj6h]hie}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj4ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj0ubjJ)}(hhh]h)}(hIEs for association requesth]hIEs for association request}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhM hjLubah}(h]h ]h"]h$]h&]uh1jIhj0ubeh}(h]h ]h"]h$]h&]uh1j)hjKhM hj.ubj*)}(h(``ie_len`` Length of assoc_ie in octets h](j0)}(h ``ie_len``h]j,)}(hjoh]hie_len}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjmubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjiubjJ)}(hhh]h)}(hLength of assoc_ie in octetsh]hLength of assoc_ie in octets}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjiubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(hA``privacy`` indicates whether privacy-enabled APs should be used h](j0)}(h ``privacy``h]j,)}(hjh]hprivacy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h4indicates whether privacy-enabled APs should be usedh]h4indicates whether privacy-enabled APs should be used}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h=``mfp`` indicate whether management frame protection is used h](j0)}(h``mfp``h]j,)}(hjh]hmfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h``crypto`` crypto settings h](j0)}(h ``crypto``h]j,)}(hjh]hcrypto}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hcrypto settingsh]hcrypto settings}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hM hj0ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj/hM hj.ubj*)}(h.``key`` WEP key for shared key authentication h](j0)}(h``key``h]j,)}(hjSh]hkey}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjQubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjMubjJ)}(hhh]h)}(h%WEP key for shared key authenticationh]h%WEP key for shared key authentication}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhM hjiubah}(h]h ]h"]h$]h&]uh1jIhjMubeh}(h]h ]h"]h$]h&]uh1j)hjhhM hj.ubj*)}(h<``key_len`` length of WEP key for shared key authentication h](j0)}(h ``key_len``h]j,)}(hjh]hkey_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h;``key_idx`` index of WEP key for shared key authentication h](j0)}(h ``key_idx``h]j,)}(hjh]hkey_idx}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(hQ``flags`` See :c:type:`enum cfg80211_assoc_req_flags ` h](j0)}(h ``flags``h]j,)}(hjh]hflags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hFSee :c:type:`enum cfg80211_assoc_req_flags `h](hSee }(hjhhhNhNubh)}(hB:c:type:`enum cfg80211_assoc_req_flags `h]j,)}(hj!h]henum cfg80211_assoc_req_flags}(hj#hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJcfg80211_assoc_req_flagsuh1hhjhM hjubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(hi``bg_scan_period`` Background scan period in seconds or -1 to indicate that default value is to be used. h](j0)}(h``bg_scan_period``h]j,)}(hjVh]hbg_scan_period}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjTubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjPubjJ)}(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.}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjlubah}(h]h ]h"]h$]h&]uh1jIhjPubeh}(h]h ]h"]h$]h&]uh1j)hjkhM 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](j0)}(h ``ht_capa``h]j,)}(hjh]hht_capa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h;``ht_capa_mask`` The bits of ht_capa which are to be used. h](j0)}(h``ht_capa_mask``h]j,)}(hjh]h ht_capa_mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h&``vht_capa`` VHT Capability overrides h](j0)}(h ``vht_capa``h]j,)}(hjh]hvht_capa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hVHT Capability overridesh]hVHT Capability overrides}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h=``vht_capa_mask`` The bits of vht_capa which are to be used. h](j0)}(h``vht_capa_mask``h]j,)}(hj<h]h vht_capa_mask}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj:ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj6ubjJ)}(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.}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQhM hjRubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j)hjQhM hj.ubj*)}(hI``pbss`` if set, connect to a PCP instead of AP. Valid for DMG networks. h](j0)}(h``pbss``h]j,)}(hjuh]hpbss}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjsubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjoubjJ)}(hhh]h)}(h?if set, connect to a PCP instead of AP. Valid for DMG networks.h]h?if set, connect to a PCP instead of AP. Valid for DMG networks.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1jIhjoubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h6``bss_select`` criteria to be used for BSS selection. h](j0)}(h``bss_select``h]j,)}(hjh]h bss_select}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h&criteria to be used for BSS selection.h]h&criteria to be used for BSS selection.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM 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. 1h](j0)}(h``prev_bssid``h]j,)}(hjh]h prev_bssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubhXB 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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h``fils_erp_username`` EAP re-authentication protocol (ERP) username part of the NAI or ``NULL`` if not specified. This is used to construct FILS wrapped data IE. h](j0)}(h``fils_erp_username``h]j,)}(hj4h]hfils_erp_username}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj2ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj.ubjJ)}(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 }(hjMhhhNhNubj,)}(h``NULL``h]hNULL}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjMubhB if not specified. This is used to construct FILS wrapped data IE.}(hjMhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjJubah}(h]h ]h"]h$]h&]uh1jIhj.ubeh}(h]h ]h"]h$]h&]uh1j)hjIhM hj.ubj*)}(hE``fils_erp_username_len`` Length of **fils_erp_username** in octets. h](j0)}(h``fils_erp_username_len``h]j,)}(hjh]hfils_erp_username_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj~ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjzubjJ)}(hhh]h)}(h*Length of **fils_erp_username** in octets.h](h Length of }(hjhhhNhNubj)}(h**fils_erp_username**h]hfils_erp_username}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh in octets.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjzubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h``fils_erp_realm`` EAP re-authentication protocol (ERP) realm part of NAI or ``NULL`` if not specified. This specifies the domain name of ER server and is used to construct FILS wrapped data IE. h](j0)}(h``fils_erp_realm``h]j,)}(hjh]hfils_erp_realm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1j+hjubhm 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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h?``fils_erp_realm_len`` Length of **fils_erp_realm** in octets. h](j0)}(h``fils_erp_realm_len``h]j,)}(hjh]hfils_erp_realm_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h'Length of **fils_erp_realm** in octets.h](h Length of }(hj0hhhNhNubj)}(h**fils_erp_realm**h]hfils_erp_realm}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubh in octets.}(hj0hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj,hM hj-ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj,hM hj.ubj*)}(h``fils_erp_next_seq_num`` The next sequence number to use in the FILS ERP messages. This is also used to construct FILS wrapped data IE. h](j0)}(h``fils_erp_next_seq_num``h]j,)}(hjbh]hfils_erp_next_seq_num}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj`ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj\ubjJ)}(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.}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjxubah}(h]h ]h"]h$]h&]uh1jIhj\ubeh}(h]h ]h"]h$]h&]uh1j)hjwhM hj.ubj*)}(h{``fils_erp_rrk`` ERP re-authentication Root Key (rRK) used to derive additional keys in FILS or ``NULL`` if not specified. h](j0)}(h``fils_erp_rrk``h]j,)}(hjh]h fils_erp_rrk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hiERP re-authentication Root Key (rRK) used to derive additional keys in FILS or ``NULL`` if not specified.h](hOERP re-authentication Root Key (rRK) used to derive additional keys in FILS or }(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh if not specified.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(h;``fils_erp_rrk_len`` Length of **fils_erp_rrk** in octets. h](j0)}(h``fils_erp_rrk_len``h]j,)}(hjh]hfils_erp_rrk_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h%Length of **fils_erp_rrk** in octets.h](h Length of }(hjhhhNhNubj)}(h**fils_erp_rrk**h]h fils_erp_rrk}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh in octets.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubj*)}(he``want_1x`` indicates user-space supports and wants to use 802.1X driver offload of 4-way handshake. h](j0)}(h ``want_1x``h]j,)}(hj3h]hwant_1x}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj1ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj-ubjJ)}(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.}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjIubah}(h]h ]h"]h$]h&]uh1jIhj-ubeh}(h]h ]h"]h$]h&]uh1j)hjHhM hj.ubj*)}(h``edmg`` define the EDMG channels. This may specify multiple channels and bonding options for the driver to choose from, based on BSS configuration.h](j0)}(h``edmg``h]j,)}(hjmh]hedmg}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjkubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjgubjJ)}(hhh]h)}(hdefine the EDMG channels. This may specify multiple channels and bonding options for the driver to choose from, based on BSS configuration.h]hdefine the EDMG channels. This may specify multiple channels and bonding options for the driver to choose from, based on BSS configuration.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubah}(h]h ]h"]h$]h&]uh1jIhjgubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj.ubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubh)}(hbThis structure provides information needed to complete IEEE 802.11 authentication and association.h]hbThis structure provides information needed to complete IEEE 802.11 authentication and association.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jscfg80211_pmksa (C struct)c.cfg80211_pmksahNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hcfg80211_pmksah]j)}(hstruct cfg80211_pmksah](j)}(hjh]hstruct}(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_pmksah]j)}(hjh]hcfg80211_pmksa}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhM hjhhubj)}(hhh]h)}(hPMK Security Associationh]hPMK Security Association}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMVhj-hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j8structeh"]h$]h&]jj8jjHjjHjjjuh1jwhhhjcchNhNubj)}(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}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubh:}(hjPhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMZhjLubj: )}(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; };}hjmsbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\hjLubh)}(h **Members**h]j)}(hj~h]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhhjLubj%)}(hhh](j*)}(h,``bssid`` The AP's BSSID (may be ``NULL``). h](j0)}(h ``bssid``h]j,)}(hjh]hbssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\hjubjJ)}(hhh]h)}(h!The AP's BSSID (may be ``NULL``).h](hThe AP’s BSSID (may be }(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM\hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM\hjubj*)}(h+``pmkid`` The identifier to refer a PMKSA. h](j0)}(h ``pmkid``h]j,)}(hjh]hpmkid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM]hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM]hjubj*)}(h{``pmk`` The PMK for the PMKSA identified by **pmkid**. This is used for key derivation by a FILS STA. Otherwise, ``NULL``. h](j0)}(h``pmk``h]j,)}(hj!h]hpmk}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM_hjubjJ)}(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 }(hj:hhhNhNubj)}(h **pmkid**h]hpmkid}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubh<. This is used for key derivation by a FILS STA. Otherwise, }(hj:hhhNhNubj,)}(h``NULL``h]hNULL}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj:ubh.}(hj:hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^hj7ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj6hM_hjubj*)}(h{``pmk_len`` Length of the **pmk**. The length of **pmk** can differ depending on the hash algorithm used to generate this. h](j0)}(h ``pmk_len``h]j,)}(hjh]hpmk_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj}ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMahjyubjJ)}(hhh]h)}(hnLength of the **pmk**. The length of **pmk** can differ depending on the hash algorithm used to generate this.h](hLength of the }(hjhhhNhNubj)}(h**pmk**h]hpmk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh. The length of }(hjhhhNhNubj)}(h**pmk**h]hpmk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhB can differ depending on the hash algorithm used to generate this.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM`hjubah}(h]h ]h"]h$]h&]uh1jIhjyubeh}(h]h ]h"]h$]h&]uh1j)hjhMahjubj*)}(hs``ssid`` SSID to specify the ESS within which a PMKSA is valid when using FILS cache identifier (may be ``NULL``). h](j0)}(h``ssid``h]j,)}(hjh]hssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMchjubjJ)}(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&]uh1j+hjubh).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMbhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMchjubj*)}(h/``ssid_len`` Length of the **ssid** in octets. h](j0)}(h ``ssid_len``h]j,)}(hj)h]hssid_len}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj'ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMdhj#ubjJ)}(hhh]h)}(h!Length of the **ssid** in octets.h](hLength of the }(hjBhhhNhNubj)}(h**ssid**h]hssid}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubh in octets.}(hjBhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj>hMdhj?ubah}(h]h ]h"]h$]h&]uh1jIhj#ubeh}(h]h ]h"]h$]h&]uh1j)hj>hMdhjubj*)}(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](j0)}(h ``cache_id``h]j,)}(hjth]hcache_id}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjrubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMghjnubjJ)}(hhh]h)}(h2-octet cache identifier advertized by a FILS AP identifying the scope of PMKSA. This is valid only if **ssid_len** is non-zero (may be ``NULL``).h](hg2-octet cache identifier advertized by a FILS AP identifying the scope of PMKSA. This is valid only if }(hjhhhNhNubj)}(h **ssid_len**h]hssid_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh is non-zero (may be }(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh).}(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&]uh1jIhjnubeh}(h]h ]h"]h$]h&]uh1j)hjhMghjubj*)}(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](j0)}(h``pmk_lifetime``h]j,)}(hjh]h pmk_lifetime}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMmhjubjJ)}(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.hhMhhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMmhjubj*)}(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](j0)}(h``pmk_reauth_threshold``h]j,)}(hj h]hpmk_reauth_threshold}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMqhjubjJ)}(hhh]h)}(hXCThreshold time for reauthentication (percentage of PMK lifetime, dot11RSNAConfigPMKReauthThreshold) or 0 if not specified. Drivers are expected to trigger a full authentication instead of using this PMKSA for caching when reassociating to a new BSS after this threshold to generate a new PMK before the current one expires.h]hXCThreshold time for reauthentication (percentage of PMK lifetime, dot11RSNAConfigPMKReauthThreshold) or 0 if not specified. Drivers are expected to trigger a full authentication instead of using this PMKSA for caching when reassociating to a new BSS after this threshold to generate a new PMK before the current one expires.}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMnhj"ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj!hMqhjubeh}(h]h ]h"]h$]h&]uh1j$hjLubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjOh]h Description}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMuhjcchhubh)}(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.}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMWhjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jscfg80211_ops (C struct)c.cfg80211_opshNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(h cfg80211_opsh]j)}(hstruct cfg80211_opsh](j)}(hjh]hstruct}(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)}(h cfg80211_opsh]j)}(hjh]h cfg80211_ops}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM]ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM]ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhM]hjhhubj)}(hhh]h)}(h.backend description for wireless configurationh]h.backend description for wireless configuration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM7hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM]ubeh}(h]h ](j8structeh"]h$]h&]jj8jjjjjjjuh1jwhhhjcchNhNubj)}(hXr**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 wireless_dev *wdev, int link_id, u8 key_index, bool pairwise, const u8 *mac_addr, struct key_params *params); int (*get_key)(struct wiphy *wiphy, struct wireless_dev *wdev, 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 wireless_dev *wdev, 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 wireless_dev *wdev, int link_id, u8 key_index); int (*set_default_beacon_key)(struct wiphy *wiphy, struct wireless_dev *wdev, 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 wireless_dev *wdev, const u8 *mac, struct station_parameters *params); int (*del_station)(struct wiphy *wiphy, struct wireless_dev *wdev, struct station_del_parameters *params); int (*change_station)(struct wiphy *wiphy, struct wireless_dev *wdev, const u8 *mac, struct station_parameters *params); int (*get_station)(struct wiphy *wiphy, struct wireless_dev *wdev, const u8 *mac, struct station_info *sinfo); int (*dump_station)(struct wiphy *wiphy, struct wireless_dev *wdev, int idx, u8 *mac, struct station_info *sinfo); int (*add_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst, const u8 *next_hop); int (*del_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst); int (*change_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst, const u8 *next_hop); int (*get_mpath)(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *next_hop, struct mpath_info *pinfo); int (*dump_mpath)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *next_hop, struct mpath_info *pinfo); int (*get_mpp)(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *mpp, struct mpath_info *pinfo); int (*dump_mpp)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *mpp, struct mpath_info *pinfo); int (*get_mesh_config)(struct wiphy *wiphy, struct net_device *dev, struct mesh_config *conf); int (*update_mesh_config)(struct wiphy *wiphy, struct net_device *dev, u32 mask, const struct mesh_config *nconf); int (*join_mesh)(struct wiphy *wiphy, struct net_device *dev, const struct mesh_config *conf, const struct mesh_setup *setup); int (*leave_mesh)(struct wiphy *wiphy, struct net_device *dev); int (*join_ocb)(struct wiphy *wiphy, struct net_device *dev, struct ocb_setup *setup); int (*leave_ocb)(struct wiphy *wiphy, struct net_device *dev); int (*change_bss)(struct wiphy *wiphy, struct net_device *dev, struct bss_parameters *params); void (*inform_bss)(struct wiphy *wiphy, struct cfg80211_bss *bss, const struct cfg80211_bss_ies *ies, void *data); int (*set_txq_params)(struct wiphy *wiphy, struct net_device *dev, struct ieee80211_txq_params *params); int (*libertas_set_mesh_channel)(struct wiphy *wiphy, struct net_device *dev, struct ieee80211_channel *chan); int (*set_monitor_channel)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_chan_def *chandef); int (*scan)(struct wiphy *wiphy, struct cfg80211_scan_request *request); void (*abort_scan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*auth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_auth_request *req); int (*assoc)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_assoc_request *req); int (*deauth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_deauth_request *req); int (*disassoc)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_disassoc_request *req); int (*connect)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_connect_params *sme); int (*update_connect_params)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_connect_params *sme, u32 changed); int (*disconnect)(struct wiphy *wiphy, struct net_device *dev, u16 reason_code); int (*join_ibss)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ibss_params *params); int (*leave_ibss)(struct wiphy *wiphy, struct net_device *dev); int (*set_mcast_rate)(struct wiphy *wiphy, struct net_device *dev, int rate[NUM_NL80211_BANDS]); int (*set_wiphy_params)(struct wiphy *wiphy, int radio_idx, u32 changed); int (*set_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, int radio_idx, enum nl80211_tx_power_setting type, int mbm); int (*get_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, int radio_idx, unsigned int link_id, int *dbm); void (*rfkill_poll)(struct wiphy *wiphy); #ifdef CONFIG_NL80211_TESTMODE; int (*testmode_cmd)(struct wiphy *wiphy, struct wireless_dev *wdev, void *data, int len); int (*testmode_dump)(struct wiphy *wiphy, struct sk_buff *skb, struct netlink_callback *cb, void *data, int len); #endif; int (*set_bitrate_mask)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id, const u8 *peer, const struct cfg80211_bitrate_mask *mask); int (*dump_survey)(struct wiphy *wiphy, struct net_device *netdev, int idx, struct survey_info *info); int (*set_pmksa)(struct wiphy *wiphy, struct net_device *netdev, struct cfg80211_pmksa *pmksa); int (*del_pmksa)(struct wiphy *wiphy, struct net_device *netdev, struct cfg80211_pmksa *pmksa); int (*flush_pmksa)(struct wiphy *wiphy, struct net_device *netdev); int (*remain_on_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, struct ieee80211_channel *chan, unsigned int duration, u64 *cookie); int (*cancel_remain_on_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*mgmt_tx)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_mgmt_tx_params *params, u64 *cookie); int (*mgmt_tx_cancel_wait)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*set_power_mgmt)(struct wiphy *wiphy, struct net_device *dev, bool enabled, int timeout); int (*set_cqm_rssi_config)(struct wiphy *wiphy, struct net_device *dev, s32 rssi_thold, u32 rssi_hyst); int (*set_cqm_rssi_range_config)(struct wiphy *wiphy, struct net_device *dev, s32 rssi_low, s32 rssi_high); int (*set_cqm_txe_config)(struct wiphy *wiphy, struct net_device *dev, u32 rate, u32 pkts, u32 intvl); void (*update_mgmt_frame_registrations)(struct wiphy *wiphy, struct wireless_dev *wdev, struct mgmt_frame_regs *upd); int (*set_antenna)(struct wiphy *wiphy, int radio_idx, u32 tx_ant, u32 rx_ant); int (*get_antenna)(struct wiphy *wiphy, int radio_idx, u32 *tx_ant, u32 *rx_ant); int (*sched_scan_start)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_sched_scan_request *request); int (*sched_scan_stop)(struct wiphy *wiphy, struct net_device *dev, u64 reqid); int (*set_rekey_data)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_gtk_rekey_data *data); int (*tdls_mgmt)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, int link_id, u8 action_code, u8 dialog_token, u16 status_code, u32 peer_capability, bool initiator, const u8 *buf, size_t len); int (*tdls_oper)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, enum nl80211_tdls_operation oper); int (*probe_client)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, u64 *cookie); int (*set_noack_map)(struct wiphy *wiphy, struct net_device *dev, u16 noack_map); int (*get_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, unsigned int link_id, struct cfg80211_chan_def *chandef); int (*start_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); void (*stop_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_mac_acl)(struct wiphy *wiphy, struct net_device *dev, const struct cfg80211_acl_data *params); int (*start_radar_detection)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_chan_def *chandef, u32 cac_time_ms, int link_id); void (*end_cac)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id); int (*update_ft_ies)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_update_ft_ies_params *ftie); int (*crit_proto_start)(struct wiphy *wiphy, struct wireless_dev *wdev, enum nl80211_crit_proto_id protocol, u16 duration); void (*crit_proto_stop)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_coalesce)(struct wiphy *wiphy, struct cfg80211_coalesce *coalesce); int (*channel_switch)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_csa_settings *params); int (*set_qos_map)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_qos_map *qos_map); int (*set_ap_chanwidth)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id, struct cfg80211_chan_def *chandef); int (*add_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer, u8 user_prio, u16 admitted_time); int (*del_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer); int (*tdls_channel_switch)(struct wiphy *wiphy, struct net_device *dev, const u8 *addr, u8 oper_class, struct cfg80211_chan_def *chandef); void (*tdls_cancel_channel_switch)(struct wiphy *wiphy, struct net_device *dev, const u8 *addr); int (*start_nan)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf); void (*stop_nan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*add_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_func *nan_func); void (*del_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*nan_change_conf)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf, u32 changes); int (*nan_set_local_sched)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_local_sched *sched); int (*nan_set_peer_sched)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_peer_sched *sched); 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. ``nan_set_local_sched`` configure the local schedule for NAN. The schedule consists of an array of ``cfg80211_nan_channel`` and the schedule itself, in which each entry maps each time slot to the channel on which the radio should operate on. If the chandef of a NAN channel is not changed, the channel entry must also remain unchanged. It is the driver's responsibility to verify this. ``nan_set_peer_sched`` configure the peer schedule for NAN. The schedule consists of an array of ``cfg80211_nan_channel`` and the schedule itself, in which each entry maps each time slot to a channel on which the radio should operate on. In addition, it contains more peer's schedule information such as committed DW, etc. When updating an existing peer schedule, the full new schedule is provided - partial updates are not supported, and the new schedule completely replaces the previous one. ``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&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM;hjubj: )}(hXZ6struct 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 wireless_dev *wdev, int link_id, u8 key_index, bool pairwise, const u8 *mac_addr, struct key_params *params); int (*get_key)(struct wiphy *wiphy, struct wireless_dev *wdev, 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 wireless_dev *wdev, 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 wireless_dev *wdev, int link_id, u8 key_index); int (*set_default_beacon_key)(struct wiphy *wiphy, struct wireless_dev *wdev, 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 wireless_dev *wdev, const u8 *mac, struct station_parameters *params); int (*del_station)(struct wiphy *wiphy, struct wireless_dev *wdev, struct station_del_parameters *params); int (*change_station)(struct wiphy *wiphy, struct wireless_dev *wdev, const u8 *mac, struct station_parameters *params); int (*get_station)(struct wiphy *wiphy, struct wireless_dev *wdev, const u8 *mac, struct station_info *sinfo); int (*dump_station)(struct wiphy *wiphy, struct wireless_dev *wdev, int idx, u8 *mac, struct station_info *sinfo); int (*add_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst, const u8 *next_hop); int (*del_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst); int (*change_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst, const u8 *next_hop); int (*get_mpath)(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *next_hop, struct mpath_info *pinfo); int (*dump_mpath)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *next_hop, struct mpath_info *pinfo); int (*get_mpp)(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *mpp, struct mpath_info *pinfo); int (*dump_mpp)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *mpp, struct mpath_info *pinfo); int (*get_mesh_config)(struct wiphy *wiphy, struct net_device *dev, struct mesh_config *conf); int (*update_mesh_config)(struct wiphy *wiphy, struct net_device *dev, u32 mask, const struct mesh_config *nconf); int (*join_mesh)(struct wiphy *wiphy, struct net_device *dev, const struct mesh_config *conf, const struct mesh_setup *setup); int (*leave_mesh)(struct wiphy *wiphy, struct net_device *dev); int (*join_ocb)(struct wiphy *wiphy, struct net_device *dev, struct ocb_setup *setup); int (*leave_ocb)(struct wiphy *wiphy, struct net_device *dev); int (*change_bss)(struct wiphy *wiphy, struct net_device *dev, struct bss_parameters *params); void (*inform_bss)(struct wiphy *wiphy, struct cfg80211_bss *bss, const struct cfg80211_bss_ies *ies, void *data); int (*set_txq_params)(struct wiphy *wiphy, struct net_device *dev, struct ieee80211_txq_params *params); int (*libertas_set_mesh_channel)(struct wiphy *wiphy, struct net_device *dev, struct ieee80211_channel *chan); int (*set_monitor_channel)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_chan_def *chandef); int (*scan)(struct wiphy *wiphy, struct cfg80211_scan_request *request); void (*abort_scan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*auth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_auth_request *req); int (*assoc)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_assoc_request *req); int (*deauth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_deauth_request *req); int (*disassoc)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_disassoc_request *req); int (*connect)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_connect_params *sme); int (*update_connect_params)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_connect_params *sme, u32 changed); int (*disconnect)(struct wiphy *wiphy, struct net_device *dev, u16 reason_code); int (*join_ibss)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ibss_params *params); int (*leave_ibss)(struct wiphy *wiphy, struct net_device *dev); int (*set_mcast_rate)(struct wiphy *wiphy, struct net_device *dev, int rate[NUM_NL80211_BANDS]); int (*set_wiphy_params)(struct wiphy *wiphy, int radio_idx, u32 changed); int (*set_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, int radio_idx, enum nl80211_tx_power_setting type, int mbm); int (*get_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, int radio_idx, unsigned int link_id, int *dbm); void (*rfkill_poll)(struct wiphy *wiphy); #ifdef CONFIG_NL80211_TESTMODE; int (*testmode_cmd)(struct wiphy *wiphy, struct wireless_dev *wdev, void *data, int len); int (*testmode_dump)(struct wiphy *wiphy, struct sk_buff *skb, struct netlink_callback *cb, void *data, int len); #endif; int (*set_bitrate_mask)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id, const u8 *peer, const struct cfg80211_bitrate_mask *mask); int (*dump_survey)(struct wiphy *wiphy, struct net_device *netdev, int idx, struct survey_info *info); int (*set_pmksa)(struct wiphy *wiphy, struct net_device *netdev, struct cfg80211_pmksa *pmksa); int (*del_pmksa)(struct wiphy *wiphy, struct net_device *netdev, struct cfg80211_pmksa *pmksa); int (*flush_pmksa)(struct wiphy *wiphy, struct net_device *netdev); int (*remain_on_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, struct ieee80211_channel *chan, unsigned int duration, u64 *cookie); int (*cancel_remain_on_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*mgmt_tx)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_mgmt_tx_params *params, u64 *cookie); int (*mgmt_tx_cancel_wait)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*set_power_mgmt)(struct wiphy *wiphy, struct net_device *dev, bool enabled, int timeout); int (*set_cqm_rssi_config)(struct wiphy *wiphy, struct net_device *dev, s32 rssi_thold, u32 rssi_hyst); int (*set_cqm_rssi_range_config)(struct wiphy *wiphy, struct net_device *dev, s32 rssi_low, s32 rssi_high); int (*set_cqm_txe_config)(struct wiphy *wiphy, struct net_device *dev, u32 rate, u32 pkts, u32 intvl); void (*update_mgmt_frame_registrations)(struct wiphy *wiphy, struct wireless_dev *wdev, struct mgmt_frame_regs *upd); int (*set_antenna)(struct wiphy *wiphy, int radio_idx, u32 tx_ant, u32 rx_ant); int (*get_antenna)(struct wiphy *wiphy, int radio_idx, u32 *tx_ant, u32 *rx_ant); int (*sched_scan_start)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_sched_scan_request *request); int (*sched_scan_stop)(struct wiphy *wiphy, struct net_device *dev, u64 reqid); int (*set_rekey_data)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_gtk_rekey_data *data); int (*tdls_mgmt)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, int link_id, u8 action_code, u8 dialog_token, u16 status_code, u32 peer_capability, bool initiator, const u8 *buf, size_t len); int (*tdls_oper)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, enum nl80211_tdls_operation oper); int (*probe_client)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, u64 *cookie); int (*set_noack_map)(struct wiphy *wiphy, struct net_device *dev, u16 noack_map); int (*get_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, unsigned int link_id, struct cfg80211_chan_def *chandef); int (*start_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); void (*stop_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_mac_acl)(struct wiphy *wiphy, struct net_device *dev, const struct cfg80211_acl_data *params); int (*start_radar_detection)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_chan_def *chandef, u32 cac_time_ms, int link_id); void (*end_cac)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id); int (*update_ft_ies)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_update_ft_ies_params *ftie); int (*crit_proto_start)(struct wiphy *wiphy, struct wireless_dev *wdev, enum nl80211_crit_proto_id protocol, u16 duration); void (*crit_proto_stop)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_coalesce)(struct wiphy *wiphy, struct cfg80211_coalesce *coalesce); int (*channel_switch)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_csa_settings *params); int (*set_qos_map)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_qos_map *qos_map); int (*set_ap_chanwidth)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id, struct cfg80211_chan_def *chandef); int (*add_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer, u8 user_prio, u16 admitted_time); int (*del_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer); int (*tdls_channel_switch)(struct wiphy *wiphy, struct net_device *dev, const u8 *addr, u8 oper_class, struct cfg80211_chan_def *chandef); void (*tdls_cancel_channel_switch)(struct wiphy *wiphy, struct net_device *dev, const u8 *addr); int (*start_nan)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf); void (*stop_nan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*add_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_func *nan_func); void (*del_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*nan_change_conf)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf, u32 changes); int (*nan_set_local_sched)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_local_sched *sched); int (*nan_set_peer_sched)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_peer_sched *sched); 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]hXZ6struct 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 wireless_dev *wdev, int link_id, u8 key_index, bool pairwise, const u8 *mac_addr, struct key_params *params); int (*get_key)(struct wiphy *wiphy, struct wireless_dev *wdev, 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 wireless_dev *wdev, 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 wireless_dev *wdev, int link_id, u8 key_index); int (*set_default_beacon_key)(struct wiphy *wiphy, struct wireless_dev *wdev, 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 wireless_dev *wdev, const u8 *mac, struct station_parameters *params); int (*del_station)(struct wiphy *wiphy, struct wireless_dev *wdev, struct station_del_parameters *params); int (*change_station)(struct wiphy *wiphy, struct wireless_dev *wdev, const u8 *mac, struct station_parameters *params); int (*get_station)(struct wiphy *wiphy, struct wireless_dev *wdev, const u8 *mac, struct station_info *sinfo); int (*dump_station)(struct wiphy *wiphy, struct wireless_dev *wdev, int idx, u8 *mac, struct station_info *sinfo); int (*add_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst, const u8 *next_hop); int (*del_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst); int (*change_mpath)(struct wiphy *wiphy, struct net_device *dev, const u8 *dst, const u8 *next_hop); int (*get_mpath)(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *next_hop, struct mpath_info *pinfo); int (*dump_mpath)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *next_hop, struct mpath_info *pinfo); int (*get_mpp)(struct wiphy *wiphy, struct net_device *dev, u8 *dst, u8 *mpp, struct mpath_info *pinfo); int (*dump_mpp)(struct wiphy *wiphy, struct net_device *dev, int idx, u8 *dst, u8 *mpp, struct mpath_info *pinfo); int (*get_mesh_config)(struct wiphy *wiphy, struct net_device *dev, struct mesh_config *conf); int (*update_mesh_config)(struct wiphy *wiphy, struct net_device *dev, u32 mask, const struct mesh_config *nconf); int (*join_mesh)(struct wiphy *wiphy, struct net_device *dev, const struct mesh_config *conf, const struct mesh_setup *setup); int (*leave_mesh)(struct wiphy *wiphy, struct net_device *dev); int (*join_ocb)(struct wiphy *wiphy, struct net_device *dev, struct ocb_setup *setup); int (*leave_ocb)(struct wiphy *wiphy, struct net_device *dev); int (*change_bss)(struct wiphy *wiphy, struct net_device *dev, struct bss_parameters *params); void (*inform_bss)(struct wiphy *wiphy, struct cfg80211_bss *bss, const struct cfg80211_bss_ies *ies, void *data); int (*set_txq_params)(struct wiphy *wiphy, struct net_device *dev, struct ieee80211_txq_params *params); int (*libertas_set_mesh_channel)(struct wiphy *wiphy, struct net_device *dev, struct ieee80211_channel *chan); int (*set_monitor_channel)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_chan_def *chandef); int (*scan)(struct wiphy *wiphy, struct cfg80211_scan_request *request); void (*abort_scan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*auth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_auth_request *req); int (*assoc)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_assoc_request *req); int (*deauth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_deauth_request *req); int (*disassoc)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_disassoc_request *req); int (*connect)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_connect_params *sme); int (*update_connect_params)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_connect_params *sme, u32 changed); int (*disconnect)(struct wiphy *wiphy, struct net_device *dev, u16 reason_code); int (*join_ibss)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ibss_params *params); int (*leave_ibss)(struct wiphy *wiphy, struct net_device *dev); int (*set_mcast_rate)(struct wiphy *wiphy, struct net_device *dev, int rate[NUM_NL80211_BANDS]); int (*set_wiphy_params)(struct wiphy *wiphy, int radio_idx, u32 changed); int (*set_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, int radio_idx, enum nl80211_tx_power_setting type, int mbm); int (*get_tx_power)(struct wiphy *wiphy, struct wireless_dev *wdev, int radio_idx, unsigned int link_id, int *dbm); void (*rfkill_poll)(struct wiphy *wiphy); #ifdef CONFIG_NL80211_TESTMODE; int (*testmode_cmd)(struct wiphy *wiphy, struct wireless_dev *wdev, void *data, int len); int (*testmode_dump)(struct wiphy *wiphy, struct sk_buff *skb, struct netlink_callback *cb, void *data, int len); #endif; int (*set_bitrate_mask)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id, const u8 *peer, const struct cfg80211_bitrate_mask *mask); int (*dump_survey)(struct wiphy *wiphy, struct net_device *netdev, int idx, struct survey_info *info); int (*set_pmksa)(struct wiphy *wiphy, struct net_device *netdev, struct cfg80211_pmksa *pmksa); int (*del_pmksa)(struct wiphy *wiphy, struct net_device *netdev, struct cfg80211_pmksa *pmksa); int (*flush_pmksa)(struct wiphy *wiphy, struct net_device *netdev); int (*remain_on_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, struct ieee80211_channel *chan, unsigned int duration, u64 *cookie); int (*cancel_remain_on_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*mgmt_tx)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_mgmt_tx_params *params, u64 *cookie); int (*mgmt_tx_cancel_wait)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*set_power_mgmt)(struct wiphy *wiphy, struct net_device *dev, bool enabled, int timeout); int (*set_cqm_rssi_config)(struct wiphy *wiphy, struct net_device *dev, s32 rssi_thold, u32 rssi_hyst); int (*set_cqm_rssi_range_config)(struct wiphy *wiphy, struct net_device *dev, s32 rssi_low, s32 rssi_high); int (*set_cqm_txe_config)(struct wiphy *wiphy, struct net_device *dev, u32 rate, u32 pkts, u32 intvl); void (*update_mgmt_frame_registrations)(struct wiphy *wiphy, struct wireless_dev *wdev, struct mgmt_frame_regs *upd); int (*set_antenna)(struct wiphy *wiphy, int radio_idx, u32 tx_ant, u32 rx_ant); int (*get_antenna)(struct wiphy *wiphy, int radio_idx, u32 *tx_ant, u32 *rx_ant); int (*sched_scan_start)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_sched_scan_request *request); int (*sched_scan_stop)(struct wiphy *wiphy, struct net_device *dev, u64 reqid); int (*set_rekey_data)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_gtk_rekey_data *data); int (*tdls_mgmt)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, int link_id, u8 action_code, u8 dialog_token, u16 status_code, u32 peer_capability, bool initiator, const u8 *buf, size_t len); int (*tdls_oper)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, enum nl80211_tdls_operation oper); int (*probe_client)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, u64 *cookie); int (*set_noack_map)(struct wiphy *wiphy, struct net_device *dev, u16 noack_map); int (*get_channel)(struct wiphy *wiphy, struct wireless_dev *wdev, unsigned int link_id, struct cfg80211_chan_def *chandef); int (*start_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); void (*stop_p2p_device)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_mac_acl)(struct wiphy *wiphy, struct net_device *dev, const struct cfg80211_acl_data *params); int (*start_radar_detection)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_chan_def *chandef, u32 cac_time_ms, int link_id); void (*end_cac)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id); int (*update_ft_ies)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_update_ft_ies_params *ftie); int (*crit_proto_start)(struct wiphy *wiphy, struct wireless_dev *wdev, enum nl80211_crit_proto_id protocol, u16 duration); void (*crit_proto_stop)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*set_coalesce)(struct wiphy *wiphy, struct cfg80211_coalesce *coalesce); int (*channel_switch)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_csa_settings *params); int (*set_qos_map)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_qos_map *qos_map); int (*set_ap_chanwidth)(struct wiphy *wiphy, struct net_device *dev, unsigned int link_id, struct cfg80211_chan_def *chandef); int (*add_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer, u8 user_prio, u16 admitted_time); int (*del_tx_ts)(struct wiphy *wiphy, struct net_device *dev, u8 tsid, const u8 *peer); int (*tdls_channel_switch)(struct wiphy *wiphy, struct net_device *dev, const u8 *addr, u8 oper_class, struct cfg80211_chan_def *chandef); void (*tdls_cancel_channel_switch)(struct wiphy *wiphy, struct net_device *dev, const u8 *addr); int (*start_nan)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf); void (*stop_nan)(struct wiphy *wiphy, struct wireless_dev *wdev); int (*add_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_func *nan_func); void (*del_nan_func)(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie); int (*nan_change_conf)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_conf *conf, u32 changes); int (*nan_set_local_sched)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_local_sched *sched); int (*nan_set_peer_sched)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_nan_peer_sched *sched); int (*set_multicast_to_unicast)(struct wiphy *wiphy, struct net_device *dev, const bool enabled); int (*get_txq_stats)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_txq_stats *txqstats); int (*set_pmk)(struct wiphy *wiphy, struct net_device *dev, const struct cfg80211_pmk_conf *conf); int (*del_pmk)(struct wiphy *wiphy, struct net_device *dev, const u8 *aa); int (*external_auth)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_external_auth_params *params); int (*tx_control_port)(struct wiphy *wiphy, struct net_device *dev, const u8 *buf, size_t len, const u8 *dest, const __be16 proto, const bool noencrypt, int link_id, u64 *cookie); int (*get_ftm_responder_stats)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ftm_responder_stats *ftm_stats); int (*start_pmsr)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_pmsr_request *request); void (*abort_pmsr)(struct wiphy *wiphy, struct wireless_dev *wdev, struct cfg80211_pmsr_request *request); int (*update_owe_info)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_update_owe_info *owe_info); int (*probe_mesh_link)(struct wiphy *wiphy, struct net_device *dev, const u8 *buf, size_t len); int (*set_tid_config)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_tid_config *tid_conf); int (*reset_tid_config)(struct wiphy *wiphy, struct net_device *dev, const u8 *peer, u8 tids); int (*set_sar_specs)(struct wiphy *wiphy, struct cfg80211_sar_specs *sar); int (*color_change)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_color_change_settings *params); int (*set_fils_aad)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_fils_aad *fils_aad); int (*set_radar_background)(struct wiphy *wiphy, struct cfg80211_chan_def *chandef); int (*add_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_parameters *params); int (*mod_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_parameters *params); int (*del_link_station)(struct wiphy *wiphy, struct net_device *dev, struct link_station_del_parameters *params); int (*set_hw_timestamp)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_set_hw_timestamp *hwts); int (*set_ttlm)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ttlm_params *params); u32 (*get_radio_mask)(struct wiphy *wiphy, struct net_device *dev); int (*assoc_ml_reconf)(struct wiphy *wiphy, struct net_device *dev, struct cfg80211_ml_reconf_req *req); int (*set_epcs)(struct wiphy *wiphy, struct net_device *dev, bool val); };}hj sbah}(h]h ]h"]h$]h&]jjuh1j9 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&]uh1jhjubah}(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](j0)}(h ``suspend``h]j,)}(hj<h]hsuspend}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj:ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMGhj6ubjJ)}(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 }(hjUhhhNhNubj)}(h**wow**h]hwow}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubh will be }(hjUhhhNhNubj,)}(h``NULL``h]hNULL}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjUubhU or contain the enabled Wake-on-Wireless triggers that are configured for the device.}(hjUhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMEhjRubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j)hjQhMGhj3ubj*)}(h,``resume`` wiphy device needs to be resumed h](j0)}(h ``resume``h]j,)}(hjh]hresume}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMHhjubjJ)}(hhh]h)}(h wiphy device needs to be resumedh]h wiphy device needs to be resumed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMHhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMHhj3ubj*)}(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](j0)}(h``set_wakeup``h]j,)}(hjh]h set_wakeup}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMKhjubjJ)}(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.hhMIhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMKhj3ubj*)}(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](j0)}(h``add_virtual_intf``h]j,)}(hj h]hadd_virtual_intf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMRhjubjJ)}(hhh]h)}(hXhcreate a new virtual interface with the given name, must set the struct wireless_dev's iftype. Beware: You must create the new netdev in the wiphy's network namespace! Returns the struct wireless_dev, or an ERR_PTR. For P2P device wdevs, the driver must also set the address member in the wdev. This additionally holds the RTNL to be able to do netdev changes.h]hXlcreate a new virtual interface with the given name, must set the struct wireless_dev’s iftype. Beware: You must create the new netdev in the wiphy’s network namespace! Returns the struct wireless_dev, or an ERR_PTR. For P2P device wdevs, the driver must also set the address member in the wdev. This additionally holds the RTNL to be able to do netdev changes.}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMMhj#ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj"hMRhj3ubj*)}(ht``del_virtual_intf`` remove the virtual interface This additionally holds the RTNL to be able to do netdev changes. h](j0)}(h``del_virtual_intf``h]j,)}(hjGh]hdel_virtual_intf}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjEubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMUhjAubjJ)}(hhh]h)}(h^remove the virtual interface This additionally holds the RTNL to be able to do netdev changes.h]h^remove the virtual interface This additionally holds the RTNL to be able to do netdev changes.}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMThj]ubah}(h]h ]h"]h$]h&]uh1jIhjAubeh}(h]h ]h"]h$]h&]uh1j)hj\hMUhj3ubj*)}(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](j0)}(h``change_virtual_intf``h]j,)}(hjh]hchange_virtual_intf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMYhj{ubjJ)}(hhh]h)}(hchange type/configuration of virtual interface, keep the struct wireless_dev's iftype updated. This additionally holds the RTNL to be able to do netdev changes.h]hchange type/configuration of virtual interface, keep the struct wireless_dev’s iftype updated. This additionally holds the RTNL to be able to do netdev changes.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMWhjubah}(h]h ]h"]h$]h&]uh1jIhj{ubeh}(h]h ]h"]h$]h&]uh1j)hjhMYhj3ubj*)}(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](j0)}(h``add_intf_link``h]j,)}(hjh]h add_intf_link}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM]hjubjJ)}(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.hhM[hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM]hj3ubj*)}(h?``del_intf_link`` Remove an MLO link from the given interface. h](j0)}(h``del_intf_link``h]j,)}(hjh]h del_intf_link}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^hjubjJ)}(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&]uh1hhj hM^hj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hM^hj3ubj*)}(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](j0)}(h ``add_key``h]j,)}(hj.h]hadd_key}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj,ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMchj(ubjJ)}(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. }(hjGhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubh will be }(hjGhhhNhNubj,)}(h``NULL``h]hNULL}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjGubh when adding a group key. }(hjGhhhNhNubj)}(h **link_id**h]hlink_id}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubh8 will be -1 for non-MLO connection. For MLO connection, }(hjGhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubh5 will be >= 0 for group key and -1 for pairwise key, }(hjGhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubh3 will be peer’s MLD address for MLO pairwise key.}(hjGhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM`hjDubah}(h]h ]h"]h$]h&]uh1jIhj(ubeh}(h]h ]h"]h$]h&]uh1j)hjChMchj3ubj*)}(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](j0)}(h ``get_key``h]j,)}(hjh]hget_key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMlhjubjJ)}(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&]uh1jhjubh will be }(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubhH when requesting information for a group key. All pointers given to the }(hjhhhNhNubj)}(h **callback**h]hcallback}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh 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&]uh1jhjubh8 will be -1 for non-MLO connection. For MLO connection, }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh5 will be >= 0 for group key and -1 for pairwise key, }(hjhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh3 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.hhMehjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMlhj3ubj*)}(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](j0)}(h ``del_key``h]j,)}(hjhh]hdel_key}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjfubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMrhjbubjJ)}(hhh]h)}(hX;remove a key given the **mac_addr** (``NULL`` for a group key) and **key_index**, return -ENOENT if the key doesn't exist. **link_id** will be -1 for non-MLO connection. For MLO connection, **link_id** will be >= 0 for group key and -1 for pairwise key, **mac_addr** will be peer's MLD address for MLO pairwise key.h](hremove a key given the }(hjhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh (}(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh for a group key) and }(hjhhhNhNubj)}(h **key_index**h]h key_index}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh-, return -ENOENT if the key doesn’t exist. }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh8 will be -1 for non-MLO connection. For MLO connection, }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh5 will be >= 0 for group key and -1 for pairwise key, }(hjhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh3 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.hhMnhj~ubah}(h]h ]h"]h$]h&]uh1jIhjbubeh}(h]h ]h"]h$]h&]uh1j)hj}hMrhj3ubj*)}(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](j0)}(h``set_default_key``h]j,)}(hjh]hset_default_key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMuhjubjJ)}(hhh]h)}(hoset the default key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection.h](h%set the default key on an interface. }(hj'hhhNhNubj)}(h **link_id**h]hlink_id}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'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.hhMthj$ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj#hMuhj3ubj*)}(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](j0)}(h``set_default_mgmt_key``h]j,)}(hjZh]hset_default_mgmt_key}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjXubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMxhjTubjJ)}(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. }(hjshhhNhNubj)}(h **link_id**h]hlink_id}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubh? will be >= 0 for MLO connection and -1 for non-MLO connection.}(hjshhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMwhjpubah}(h]h ]h"]h$]h&]uh1jIhjTubeh}(h]h ]h"]h$]h&]uh1j)hjohMxhj3ubj*)}(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](j0)}(h``set_default_beacon_key``h]j,)}(hjh]hset_default_beacon_key}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM{hjubjJ)}(hhh]h)}(h|set the default Beacon frame key on an interface. **link_id** will be >= 0 for MLO connection and -1 for non-MLO connection.h](h2set the default Beacon frame key on an interface. }(hjhhhNhNubj)}(h **link_id**h]hlink_id}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh? 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.hhMzhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM{hj3ubj*)}(h@``start_ap`` Start acting in AP mode defined by the parameters. h](j0)}(h ``start_ap``h]j,)}(hjh]hstart_ap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h2Start acting in AP mode defined by the parameters.h]h2Start acting in AP mode defined by the parameters.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``change_beacon``h]j,)}(hj+h]h change_beacon}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj)ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj%ubjJ)}(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.}(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&]uh1jIhj%ubeh}(h]h ]h"]h$]h&]uh1j)hj@hMhj3ubj*)}(h<``stop_ap`` Stop being an AP, including stopping beaconing. h](j0)}(h ``stop_ap``h]j,)}(hjeh]hstop_ap}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjcubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj_ubjJ)}(hhh]h)}(h/Stop being an AP, including stopping beaconing.h]h/Stop being an AP, including stopping beaconing.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhMhj{ubah}(h]h ]h"]h$]h&]uh1jIhj_ubeh}(h]h ]h"]h$]h&]uh1j)hjzhMhj3ubj*)}(h#``add_station`` Add a new station. h](j0)}(h``add_station``h]j,)}(hjh]h add_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hAdd a new station.h]hAdd a new station.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h!``del_station`` Remove a station h](j0)}(h``del_station``h]j,)}(hjh]h del_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hRemove a stationh]hRemove a station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``change_station``h]j,)}(hjh]hchange_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubjJ)}(hhh]h)}(hX>Modify a given station. Note that flags changes are not much validated in cfg80211, in particular the auth/assoc/authorized flags might come to the driver in invalid combinations -- make sure to check them, also against the existing state! Drivers must call cfg80211_check_station_change() to validate the information.h]hX>Modify a given station. Note that flags changes are not much validated in cfg80211, in particular the auth/assoc/authorized flags might come to the driver in invalid combinations -- make sure to check them, also against the existing state! Drivers must call cfg80211_check_station_change() to validate the information.}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj&ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj%hMhj3ubj*)}(hN``get_station`` get station information for the station identified by **mac** h](j0)}(h``get_station``h]j,)}(hjJh]h get_station}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjHubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjDubjJ)}(hhh]h)}(h=get station information for the station identified by **mac**h](h6get station information for the station identified by }(hjchhhNhNubj)}(h**mac**h]hmac}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubeh}(h]h ]h"]h$]h&]uh1hhj_hMhj`ubah}(h]h ]h"]h$]h&]uh1jIhjDubeh}(h]h ]h"]h$]h&]uh1j)hj_hMhj3ubj*)}(hG``dump_station`` dump station callback -- resume dump at index **idx** h](j0)}(h``dump_station``h]j,)}(hjh]h dump_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h5dump station callback -- resume dump at index **idx**h](h.dump station callback -- resume dump at index }(hjhhhNhNubj)}(h**idx**h]hidx}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h$``add_mpath`` add a fixed mesh path h](j0)}(h ``add_mpath``h]j,)}(hjh]h add_mpath}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hadd a fixed mesh pathh]hadd a fixed mesh path}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h'``del_mpath`` delete a given mesh path h](j0)}(h ``del_mpath``h]j,)}(hjh]h del_mpath}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubjJ)}(hhh]h)}(hdelete a given mesh pathh]hdelete a given mesh path}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hMhj'ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj&hMhj3ubj*)}(h*``change_mpath`` change a given mesh path h](j0)}(h``change_mpath``h]j,)}(hjJh]h change_mpath}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjHubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjDubjJ)}(hhh]h)}(hchange a given mesh pathh]hchange a given mesh path}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hMhj`ubah}(h]h ]h"]h$]h&]uh1jIhjDubeh}(h]h ]h"]h$]h&]uh1j)hj_hMhj3ubj*)}(h7``get_mpath`` get a mesh path for the given parameters h](j0)}(h ``get_mpath``h]j,)}(hjh]h get_mpath}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj}ubjJ)}(hhh]h)}(h(get a mesh path for the given parametersh]h(get a mesh path for the given parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhj}ubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hG``dump_mpath`` dump mesh path callback -- resume dump at index **idx** h](j0)}(h``dump_mpath``h]j,)}(hjh]h dump_mpath}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h;``get_mpp`` get a mesh proxy path for the given parameters h](j0)}(h ``get_mpp``h]j,)}(hjh]hget_mpp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hK``dump_mpp`` dump mesh proxy path callback -- resume dump at index **idx** h](j0)}(h ``dump_mpp``h]j,)}(hj<h]hdump_mpp}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj:ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj6ubjJ)}(hhh]h)}(h=dump mesh proxy path callback -- resume dump at index **idx**h](h6dump mesh proxy path callback -- resume dump at index }(hjUhhhNhNubj)}(h**idx**h]hidx}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubeh}(h]h ]h"]h$]h&]uh1hhjQhMhjRubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j)hjQhMhj3ubj*)}(h7``get_mesh_config`` Get the current mesh configuration h](j0)}(h``get_mesh_config``h]j,)}(hjh]hget_mesh_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj}ubjJ)}(hhh]h)}(h"Get the current mesh configurationh]h"Get the current mesh configuration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhj}ubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``update_mesh_config``h]j,)}(hjh]hupdate_mesh_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hm``join_mesh`` join the mesh network with the specified parameters (invoked with the wireless_dev mutex held) h](j0)}(h ``join_mesh``h]j,)}(hjh]h join_mesh}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h^join the mesh network with the specified parameters (invoked with the wireless_dev mutex held)h]h^join the mesh network with the specified parameters (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hMhj3ubj*)}(hY``leave_mesh`` leave the current mesh network (invoked with the wireless_dev mutex held) h](j0)}(h``leave_mesh``h]j,)}(hj0h]h leave_mesh}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj.ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj*ubjJ)}(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)}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjFubah}(h]h ]h"]h$]h&]uh1jIhj*ubeh}(h]h ]h"]h$]h&]uh1j)hjEhMhj3ubj*)}(hk``join_ocb`` join the OCB network with the specified parameters (invoked with the wireless_dev mutex held) h](j0)}(h ``join_ocb``h]j,)}(hjjh]hjoin_ocb}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjhubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMyhjdubjJ)}(hhh]h)}(h]join the OCB network with the specified parameters (invoked with the wireless_dev mutex held)h]h]join the OCB network with the specified parameters (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMxhjubah}(h]h ]h"]h$]h&]uh1jIhjdubeh}(h]h ]h"]h$]h&]uh1j)hjhMyhj3ubj*)}(hW``leave_ocb`` leave the current OCB network (invoked with the wireless_dev mutex held) h](j0)}(h ``leave_ocb``h]j,)}(hjh]h leave_ocb}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM{hjubjJ)}(hhh]h)}(hHleave the current OCB network (invoked with the wireless_dev mutex held)h]hHleave the current OCB network (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMzhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM{hj3ubj*)}(h2``change_bss`` Modify parameters for a given BSS. h](j0)}(h``change_bss``h]j,)}(hjh]h change_bss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``inform_bss``h]j,)}(hjh]h inform_bss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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.}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj-ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj,hMhj3ubj*)}(h+``set_txq_params`` Set TX queue parameters h](j0)}(h``set_txq_params``h]j,)}(hjQh]hset_txq_params}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjOubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjKubjJ)}(hhh]h)}(hSet TX queue parametersh]hSet TX queue parameters}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjgubah}(h]h ]h"]h$]h&]uh1jIhjKubeh}(h]h ]h"]h$]h&]uh1j)hjfhMhj3ubj*)}(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](j0)}(h``libertas_set_mesh_channel``h]j,)}(hjh]hlibertas_set_mesh_channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hOnly for backward compatibility for libertas, as it doesn't implement join_mesh and needs to set the channel to join the mesh instead.h]hOnly for backward compatibility for libertas, as it doesn’t implement join_mesh and needs to set the channel to join the mesh instead.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``set_monitor_channel``h]j,)}(hjh]hset_monitor_channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``scan``h]j,)}(hjh]hscan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``abort_scan``h]j,)}(hj8h]h abort_scan}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj2ubjJ)}(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().}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjNubah}(h]h ]h"]h$]h&]uh1jIhj2ubeh}(h]h ]h"]h$]h&]uh1j)hjMhMhj3ubj*)}(hd``auth`` Request to authenticate with the specified peer (invoked with the wireless_dev mutex held) h](j0)}(h``auth``h]j,)}(hjrh]hauth}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjpubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjlubjJ)}(hhh]h)}(hZRequest to authenticate with the specified peer (invoked with the wireless_dev mutex held)h]hZRequest to authenticate with the specified peer (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjlubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hf``assoc`` Request to (re)associate with the specified peer (invoked with the wireless_dev mutex held) h](j0)}(h ``assoc``h]j,)}(hjh]hassoc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h[Request to (re)associate with the specified peer (invoked with the wireless_dev mutex held)h]h[Request to (re)associate with the specified peer (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hh``deauth`` Request to deauthenticate from the specified peer (invoked with the wireless_dev mutex held) h](j0)}(h ``deauth``h]j,)}(hjh]hdeauth}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h\Request to deauthenticate from the specified peer (invoked with the wireless_dev mutex held)h]h\Request to deauthenticate from the specified peer (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hh``disassoc`` Request to disassociate from the specified peer (invoked with the wireless_dev mutex held) h](j0)}(h ``disassoc``h]j,)}(hj h]hdisassoc}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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)}(hj9hhhNhNubah}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj5hMhj3ubj*)}(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](j0)}(h ``connect``h]j,)}(hjZh]hconnect}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjXubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjTubjJ)}(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 }(hjshhhNhNubj,)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjsubhX. 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)[}(hjshhhNhNubeh}(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&]uh1jIhjTubeh}(h]h ]h"]h$]h&]uh1j)hjohMhj3ubj*)}(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](j0)}(h``update_connect_params``h]j,)}(hjh]hupdate_connect_params}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hXUpdate the connect parameters while connected to a BSS. The updated parameters can be used by driver/firmware for subsequent BSS selection (roaming) decisions and to form the Authentication/(Re)Association Request frames. This call does not request an immediate disassociation or reassociation with the current BSS, i.e., this impacts only subsequent (re)associations. The bits in changed are defined in :c:type:`enum cfg80211_connect_params_changed `. (invoked with the wireless_dev mutex held)h](hXUpdate the connect parameters while connected to a BSS. The updated parameters can be used by driver/firmware for subsequent BSS selection (roaming) decisions and to form the Authentication/(Re)Association Request frames. This call does not request an immediate disassociation or reassociation with the current BSS, i.e., this impacts only subsequent (re)associations. The bits in changed are defined in }(hjhhhNhNubh)}(hP:c:type:`enum cfg80211_connect_params_changed `h]j,)}(hjh]h$enum cfg80211_connect_params_changed}(hjhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJcfg80211_connect_params_changeduh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh,. (invoked with the wireless_dev mutex held)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``disconnect``h]j,)}(hjh]h disconnect}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hDisconnect from the BSS/ESS or stop connection attempts if connection is in progress. Once done, call cfg80211_disconnected() in case connection was already established (invoked with the wireless_dev mutex held), otherwise call cfg80211_connect_timeout().h]hDisconnect from the BSS/ESS or stop connection attempts if connection is in progress. Once done, call cfg80211_disconnected() in case connection was already established (invoked with the wireless_dev mutex held), otherwise call cfg80211_connect_timeout().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h ``join_ibss``h]j,)}(hj=h]h join_ibss}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj;ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj7ubjJ)}(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)}(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&]uh1jIhj7ubeh}(h]h ]h"]h$]h&]uh1j)hjRhMhj3ubj*)}(hJ``leave_ibss`` Leave the IBSS. (invoked with the wireless_dev mutex held) h](j0)}(h``leave_ibss``h]j,)}(hjwh]h leave_ibss}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjuubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubjJ)}(hhh]h)}(h:Leave the IBSS. (invoked with the wireless_dev mutex held)h]h:Leave the IBSS. (invoked with the wireless_dev mutex held)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjqubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h[``set_mcast_rate`` Set the specified multicast rate (only if vif is in ADHOC or MESH mode) h](j0)}(h``set_mcast_rate``h]j,)}(hjh]hset_mcast_rate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hGSet the specified multicast rate (only if vif is in ADHOC or MESH mode)h]hGSet the specified multicast rate (only if vif is in ADHOC or MESH mode)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``set_wiphy_params``h]j,)}(hjh]hset_wiphy_params}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hXNotify that wiphy parameters have changed; **changed** bitfield (see :c:type:`enum wiphy_params_flags `) describes which values have changed. The actual parameter values are available in struct wiphy. If returning an error, no value should be changed.h](h+Notify that wiphy parameters have changed; }(hjhhhNhNubj)}(h **changed**h]hchanged}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh bitfield (see }(hjhhhNhNubh)}(h6:c:type:`enum wiphy_params_flags `h]j,)}(hj h]henum wiphy_params_flags}(hj"hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJwiphy_params_flagsuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubh) describes which values have changed. The actual parameter values are available in struct wiphy. If returning an error, no value should be changed.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj=hMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``set_tx_power``h]j,)}(hjZh]h set_tx_power}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjXubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjTubjJ)}(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 }(hjshhhNhNubj,)}(h``NULL``h]hNULL}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjsubh4 if power was set for the wiphy, and will always be }(hjshhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjsubhY unless the driver supports per-vif TX power (as advertised by the nl80211 feature flag.)}(hjshhhNhNubeh}(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&]uh1jIhjTubeh}(h]h ]h"]h$]h&]uh1j)hjohMhj3ubj*)}(hZ``get_tx_power`` store the current TX power into the dbm variable; return 0 if successful h](j0)}(h``get_tx_power``h]j,)}(hjh]h get_tx_power}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hHstore the current TX power into the dbm variable; return 0 if successfulh]hHstore the current TX power into the dbm variable; return 0 if successful}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(he``rfkill_poll`` polls the hw rfkill line, use cfg80211 reporting functions to adjust rfkill hw state h](j0)}(h``rfkill_poll``h]j,)}(hjh]h rfkill_poll}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hTpolls the hw rfkill line, use cfg80211 reporting functions to adjust rfkill hw stateh]hTpolls the hw rfkill line, use cfg80211 reporting functions to adjust rfkill hw state}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hC``testmode_cmd`` run a test mode command; **wdev** may be ``NULL`` h](j0)}(h``testmode_cmd``h]j,)}(hj,h]h testmode_cmd}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj*ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj&ubjJ)}(hhh]h)}(h1run a test mode command; **wdev** may be ``NULL``h](hrun a test mode command; }(hjEhhhNhNubj)}(h**wdev**h]hwdev}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubh may be }(hjEhhhNhNubj,)}(h``NULL``h]hNULL}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjEubeh}(h]h ]h"]h$]h&]uh1hhjAhM hjBubah}(h]h ]h"]h$]h&]uh1jIhj&ubeh}(h]h ]h"]h$]h&]uh1j)hjAhM hj3ubj*)}(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](j0)}(h``testmode_dump``h]j,)}(hjh]h testmode_dump}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hXImplement a test mode dump. The cb->args[2] and up may be used by the function, but 0 and 1 must not be touched. Additionally, return error codes other than -ENOBUFS and -ENOENT will terminate the dump and return to userspace with an error, so be careful. If any data was passed in from userspace then the data/len arguments will be present and point to the data contained in ``NL80211_ATTR_TESTDATA``.h](hXxImplement a test mode dump. The cb->args[2] and up may be used by the function, but 0 and 1 must not be touched. Additionally, return error codes other than -ENOBUFS and -ENOENT will terminate the dump and return to userspace with an error, so be careful. If any data was passed in from userspace then the data/len arguments will be present and point to the data contained in }(hjhhhNhNubj,)}(h``NL80211_ATTR_TESTDATA``h]hNL80211_ATTR_TESTDATA}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh.}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h8``set_bitrate_mask`` set the bitrate mask configuration h](j0)}(h``set_bitrate_mask``h]j,)}(hjh]hset_bitrate_mask}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h"set the bitrate mask configurationh]h"set the bitrate mask configuration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h-``dump_survey`` get site survey information. h](j0)}(h``dump_survey``h]j,)}(hj h]h dump_survey}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hget site survey information.h]hget site survey information.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h ``set_pmksa``h]j,)}(hjCh]h set_pmksa}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjAubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj=ubjJ)}(hhh]h)}(hCache a PMKID for a BSSID. This is mostly useful for fullmac devices running firmwares capable of generating the (re) association RSN IE. It allows for faster roaming between WPA2 BSSIDs.h]hCache a PMKID for a BSSID. This is mostly useful for fullmac devices running firmwares capable of generating the (re) association RSN IE. It allows for faster roaming between WPA2 BSSIDs.}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjYubah}(h]h ]h"]h$]h&]uh1jIhj=ubeh}(h]h ]h"]h$]h&]uh1j)hjXhMhj3ubj*)}(h%``del_pmksa`` Delete a cached PMKID. h](j0)}(h ``del_pmksa``h]j,)}(hj}h]h del_pmksa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj{ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjwubjJ)}(hhh]h)}(hDelete a cached PMKID.h]hDelete a cached PMKID.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjwubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h)``flush_pmksa`` Flush all cached PMKIDs. h](j0)}(h``flush_pmksa``h]j,)}(hjh]h flush_pmksa}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hFlush all cached PMKIDs.h]hFlush all cached PMKIDs.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``remain_on_channel``h]j,)}(hjh]hremain_on_channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hX-Request the driver to remain awake on the specified channel for the specified duration to complete an off-channel operation (e.g., public action frame exchange). When the driver is ready on the requested channel, it must indicate this with an event notification by calling cfg80211_ready_on_channel().h]hX-Request the driver to remain awake on the specified channel for the specified duration to complete an off-channel operation (e.g., public action frame exchange). When the driver is ready on the requested channel, it must indicate this with an event notification by calling cfg80211_ready_on_channel().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``cancel_remain_on_channel``h]j,)}(hj)h]hcancel_remain_on_channel}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj'ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj#ubjJ)}(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.}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj?ubah}(h]h ]h"]h$]h&]uh1jIhj#ubeh}(h]h ]h"]h$]h&]uh1j)hj>hMhj3ubj*)}(h)``mgmt_tx`` Transmit a management frame. h](j0)}(h ``mgmt_tx``h]j,)}(hjch]hmgmt_tx}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjaubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj]ubjJ)}(hhh]h)}(hTransmit a management frame.h]hTransmit a management frame.}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxhMhjyubah}(h]h ]h"]h$]h&]uh1jIhj]ubeh}(h]h ]h"]h$]h&]uh1j)hjxhMhj3ubj*)}(he``mgmt_tx_cancel_wait`` Cancel the wait time from transmitting a management frame on another channel h](j0)}(h``mgmt_tx_cancel_wait``h]j,)}(hjh]hmgmt_tx_cancel_wait}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hLCancel the wait time from transmitting a management frame on another channelh]hLCancel the wait time from transmitting a management frame on another channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hj3ubj*)}(h``set_power_mgmt`` Configure WLAN power management. A timeout value of -1 allows the driver to adjust the dynamic ps timeout value. h](j0)}(h``set_power_mgmt``h]j,)}(hjh]hset_power_mgmt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``set_cqm_rssi_config``h]j,)}(hjh]hset_cqm_rssi_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj ubjJ)}(hhh]h)}(hXConfigure connection quality monitor RSSI threshold. After configuration, the driver should (soon) send an event indicating the current level is above/below the configured threshold; this may need some care when the configuration is changed (without first being disabled.)h]hXConfigure connection quality monitor RSSI threshold. After configuration, the driver should (soon) send an event indicating the current level is above/below the configured threshold; this may need some care when the configuration is changed (without first being disabled.)}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj&ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj%hM hj3ubj*)}(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](j0)}(h``set_cqm_rssi_range_config``h]j,)}(hjJh]hset_cqm_rssi_range_config}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjHubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM%hjDubjJ)}(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 }(hjchhhNhNubj,)}(h%``NL80211_EXT_FEATURE_CQM_RSSI_LIST``h]h!NL80211_EXT_FEATURE_CQM_RSSI_LIST}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjcubhT if this method is implemented. If it is provided then there’s no point providing }(hjchhhNhNubj)}(h**set_cqm_rssi_config**h]hset_cqm_rssi_config}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubh.}(hjchhhNhNubeh}(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&]uh1jIhjDubeh}(h]h ]h"]h$]h&]uh1j)hj_hM%hj3ubj*)}(hQ``set_cqm_txe_config`` Configure connection quality monitor TX error thresholds. h](j0)}(h``set_cqm_txe_config``h]j,)}(hjh]hset_cqm_txe_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM'hjubjJ)}(hhh]h)}(h9Configure connection quality monitor TX error thresholds.h]h9Configure connection quality monitor TX error thresholds.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM&hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM'hj3ubj*)}(h``update_mgmt_frame_registrations`` Notify the driver that management frame registrations were updated. The callback is allowed to sleep. h](j0)}(h#``update_mgmt_frame_registrations``h]j,)}(hjh]hupdate_mgmt_frame_registrations}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM1hjubjJ)}(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.hhM0hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM1hj3ubj*)}(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](j0)}(h``set_antenna``h]j,)}(hjh]h set_antenna}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM6hjubjJ)}(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 }(hj5hhhNhNubj)}(h!**NL80211_ATTR_WIPHY_ANTENNA_TX**h]hNL80211_ATTR_WIPHY_ANTENNA_TX}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubh).}(hj5hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM3hj2ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj1hM6hj3ubj*)}(hP``get_antenna`` Get current antenna configuration from device (tx_ant, rx_ant). h](j0)}(h``get_antenna``h]j,)}(hjhh]h get_antenna}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjfubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM8hjbubjJ)}(hhh]h)}(h?Get current antenna configuration from device (tx_ant, rx_ant).h]h?Get current antenna configuration from device (tx_ant, rx_ant).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}hM8hj~ubah}(h]h ]h"]h$]h&]uh1jIhjbubeh}(h]h ]h"]h$]h&]uh1j)hj}hM8hj3ubj*)}(h@``sched_scan_start`` Tell the driver to start a scheduled scan. h](j0)}(h``sched_scan_start``h]j,)}(hjh]hsched_scan_start}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM(hjubjJ)}(hhh]h)}(h*Tell the driver to start a scheduled scan.h]h*Tell the driver to start a scheduled scan.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM(hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM(hj3ubj*)}(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](j0)}(h``sched_scan_stop``h]j,)}(hjh]hsched_scan_stop}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM.hjubjJ)}(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&]uh1jhjubh may be called immediately after that again and should not fail in that case. The driver should not call cfg80211_sched_scan_stopped() for a requested stop (when this method returns 0).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM)hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM.hj3ubj*)}(hJ``set_rekey_data`` give the data necessary for GTK rekeying to the driver h](j0)}(h``set_rekey_data``h]j,)}(hj&h]hset_rekey_data}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj$ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM}hj ubjJ)}(hhh]h)}(h6give the data necessary for GTK rekeying to the driverh]h6give the data necessary for GTK rekeying to the driver}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;hM}hj<ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj;hM}hj3ubj*)}(h0``tdls_mgmt`` Transmit a TDLS management frame. h](j0)}(h ``tdls_mgmt``h]j,)}(hj_h]h tdls_mgmt}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj]ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM:hjYubjJ)}(hhh]h)}(h!Transmit a TDLS management frame.h]h!Transmit a TDLS management frame.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjthM:hjuubah}(h]h ]h"]h$]h&]uh1jIhjYubeh}(h]h ]h"]h$]h&]uh1j)hjthM:hj3ubj*)}(hJ``tdls_oper`` Perform a high-level TDLS operation (e.g. TDLS link setup). h](j0)}(h ``tdls_oper``h]j,)}(hjh]h tdls_oper}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM;hjubjJ)}(hhh]h)}(h;Perform a high-level TDLS operation (e.g. TDLS link setup).h]h;Perform a high-level TDLS operation (e.g. TDLS link setup).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM;hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM;hj3ubj*)}(hs``probe_client`` probe an associated client, must return a cookie that it later passes to cfg80211_probe_status(). h](j0)}(h``probe_client``h]j,)}(hjh]h probe_client}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM>hjubjJ)}(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.hhM=hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM>hj3ubj*)}(h2``set_noack_map`` Set the NoAck Map for the TIDs. h](j0)}(h``set_noack_map``h]j,)}(hj h]h set_noack_map}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM@hjubjJ)}(hhh]h)}(hSet the NoAck Map for the TIDs.h]hSet the NoAck Map for the TIDs.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM@hj!ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hM@hj3ubj*)}(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](j0)}(h``get_channel``h]j,)}(hjDh]h get_channel}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjBubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMDhj>ubjJ)}(hhh]h)}(hGet the current operating channel for the virtual interface. For monitor interfaces, it should return ``NULL`` unless there's a single current monitoring channel.h](hfGet the current operating channel for the virtual interface. For monitor interfaces, it should return }(hj]hhhNhNubj,)}(h``NULL``h]hNULL}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj]ubh6 unless there’s a single current monitoring channel.}(hj]hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMBhjZubah}(h]h ]h"]h$]h&]uh1jIhj>ubeh}(h]h ]h"]h$]h&]uh1j)hjYhMDhj3ubj*)}(h1``start_p2p_device`` Start the given P2P device. h](j0)}(h``start_p2p_device``h]j,)}(hjh]hstart_p2p_device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMFhjubjJ)}(hhh]h)}(hStart the given P2P device.h]hStart the given P2P device.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMFhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMFhj3ubj*)}(h/``stop_p2p_device`` Stop the given P2P device. h](j0)}(h``stop_p2p_device``h]j,)}(hjh]hstop_p2p_device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMGhjubjJ)}(hhh]h)}(hStop the given P2P device.h]hStop the given P2P device.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMGhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMGhj3ubj*)}(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](j0)}(h``set_mac_acl``h]j,)}(hjh]h set_mac_acl}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMNhjubjJ)}(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.hhMIhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMNhj3ubj*)}(h?``start_radar_detection`` Start radar detection in the driver. h](j0)}(h``start_radar_detection``h]j,)}(hj<h]hstart_radar_detection}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj:ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMPhj6ubjJ)}(hhh]h)}(h$Start radar detection in the driver.h]h$Start radar detection in the driver.}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQhMPhjRubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j)hjQhMPhj3ubj*)}(hY``end_cac`` End running CAC, probably because a related CAC was finished on another phy. h](j0)}(h ``end_cac``h]j,)}(hjuh]hend_cac}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjsubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMShjoubjJ)}(hhh]h)}(hLEnd running CAC, probably because a related CAC was finished on another phy.h]hLEnd running CAC, probably because a related CAC was finished on another phy.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMRhjubah}(h]h ]h"]h$]h&]uh1jIhjoubeh}(h]h ]h"]h$]h&]uh1j)hjhMShj3ubj*)}(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](j0)}(h``update_ft_ies``h]j,)}(hjh]h update_ft_ies}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMWhjubjJ)}(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.hhMUhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMWhj3ubj*)}(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](j0)}(h``crit_proto_start``h]j,)}(hjh]hcrit_proto_start}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM[hjubjJ)}(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.hhMYhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM[hj3ubj*)}(hy``crit_proto_stop`` Indicates critical protocol no longer needs increased link reliability. This operation can not fail. h](j0)}(h``crit_proto_stop``h]j,)}(hj#h]hcrit_proto_stop}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj!ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM]hjubjJ)}(hhh]h)}(hdIndicates critical protocol no longer needs increased link reliability. This operation can not fail.h]hdIndicates critical protocol no longer needs increased link reliability. This operation can not fail.}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\hj9ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj8hM]hj3ubj*)}(h*``set_coalesce`` Set coalesce parameters. h](j0)}(h``set_coalesce``h]j,)}(hj]h]h set_coalesce}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj[ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM^hjWubjJ)}(hhh]h)}(hSet coalesce parameters.h]hSet coalesce parameters.}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrhM^hjsubah}(h]h ]h"]h$]h&]uh1jIhjWubeh}(h]h ]h"]h$]h&]uh1j)hjrhM^hj3ubj*)}(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](j0)}(h``channel_switch``h]j,)}(hjh]hchannel_switch}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMehjubjJ)}(hhh]h)}(hXYinitiate channel-switch procedure (with CSA). Driver is responsible for veryfing if the switch is possible. Since this is inherently tricky driver may decide to disconnect an interface later with cfg80211_stop_iface(). This doesn't mean driver can accept everything. It should do it's best to verify requests and reject them as soon as possible.h]hX]initiate channel-switch procedure (with CSA). Driver is responsible for veryfing if the switch is possible. Since this is inherently tricky driver may decide to disconnect an interface later with cfg80211_stop_iface(). This doesn’t mean driver can accept everything. It should do it’s best to verify requests and reject them as soon as possible.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM`hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMehj3ubj*)}(h:``set_qos_map`` Set QoS mapping information to the driver h](j0)}(h``set_qos_map``h]j,)}(hjh]h set_qos_map}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMghjubjJ)}(hhh]h)}(h)Set QoS mapping information to the driverh]h)Set QoS mapping information to the driver}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMghjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMghj3ubj*)}(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](j0)}(h``set_ap_chanwidth``h]j,)}(hj h]hset_ap_chanwidth}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMkhjubjJ)}(hhh]h)}(hSet the AP (including P2P GO) mode channel width for the given interface This is used e.g. for dynamic HT 20/40 MHz channel width changes during the lifetime of the BSS.h]hSet the AP (including P2P GO) mode channel width for the given interface This is used e.g. for dynamic HT 20/40 MHz channel width changes during the lifetime of the BSS.}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMihjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMkhj3ubj*)}(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](j0)}(h ``add_tx_ts``h]j,)}(hjCh]h add_tx_ts}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjAubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMuhj=ubjJ)}(hhh]h)}(hXvalidate (if admitted_time is 0) or add a TX TS to the device with the given parameters; action frame exchange has been handled by userspace so this just has to modify the TX path to take the TS into account. If the admitted time is 0 just validate the parameters to make sure the session can be created at all; it is valid to just always return success for that but that may result in inefficient behaviour (handshake with the peer followed by immediate teardown when the addition is later rejected)h]hXvalidate (if admitted_time is 0) or add a TX TS to the device with the given parameters; action frame exchange has been handled by userspace so this just has to modify the TX path to take the TS into account. If the admitted time is 0 just validate the parameters to make sure the session can be created at all; it is valid to just always return success for that but that may result in inefficient behaviour (handshake with the peer followed by immediate teardown when the addition is later rejected)}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMmhjYubah}(h]h ]h"]h$]h&]uh1jIhj=ubeh}(h]h ]h"]h$]h&]uh1j)hjXhMuhj3ubj*)}(h'``del_tx_ts`` remove an existing TX TS h](j0)}(h ``del_tx_ts``h]j,)}(hj}h]h del_tx_ts}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj{ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMvhjwubjJ)}(hhh]h)}(hremove an existing TX TSh]hremove an existing TX TS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMvhjubah}(h]h ]h"]h$]h&]uh1jIhjwubeh}(h]h ]h"]h$]h&]uh1j)hjhMvhj3ubj*)}(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](j0)}(h``tdls_channel_switch``h]j,)}(hjh]htdls_channel_switch}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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.hhM}hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``tdls_cancel_channel_switch``h]j,)}(hjh]htdls_cancel_channel_switch}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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.}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h'``start_nan`` Start the NAN interface. h](j0)}(h ``start_nan``h]j,)}(hj*h]h start_nan}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj(ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj$ubjJ)}(hhh]h)}(hStart the NAN interface.h]hStart the NAN interface.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hMhj@ubah}(h]h ]h"]h$]h&]uh1jIhj$ubeh}(h]h ]h"]h$]h&]uh1j)hj?hMhj3ubj*)}(h%``stop_nan`` Stop the NAN interface. h](j0)}(h ``stop_nan``h]j,)}(hjch]hstop_nan}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjaubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj]ubjJ)}(hhh]h)}(hStop the NAN interface.h]hStop the NAN interface.}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxhMhjyubah}(h]h ]h"]h$]h&]uh1jIhj]ubeh}(h]h ]h"]h$]h&]uh1j)hjxhMhj3ubj*)}(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](j0)}(h``add_nan_func``h]j,)}(hjh]h add_nan_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hXeAdd a NAN function. Returns negative value on failure. On success **nan_func** ownership is transferred to the driver and it may access it outside of the scope of this function. The driver should free the **nan_func** when no longer needed by calling cfg80211_free_nan_func(). On success the driver should assign an instance_id in the provided **nan_func**.h](hBAdd a NAN function. Returns negative value on failure. On success }(hjhhhNhNubj)}(h **nan_func**h]hnan_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh ownership is transferred to the driver and it may access it outside of the scope of this function. The driver should free the }(hjhhhNhNubj)}(h **nan_func**h]hnan_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh when no longer needed by calling cfg80211_free_nan_func(). On success the driver should assign an instance_id in the provided }(hjhhhNhNubj)}(h **nan_func**h]hnan_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h(``del_nan_func`` Delete a NAN function. h](j0)}(h``del_nan_func``h]j,)}(hj h]h del_nan_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hDelete a NAN function.h]hDelete a NAN function.}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hMhj"ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj!hMhj3ubj*)}(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](j0)}(h``nan_change_conf``h]j,)}(hjEh]hnan_change_conf}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjCubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj?ubjJ)}(hhh]h)}(hchanges NAN configuration. The changed parameters must be specified in **changes** (using :c:type:`enum cfg80211_nan_conf_changes `); All other parameters must be ignored.h](hGchanges NAN configuration. The changed parameters must be specified in }(hj^hhhNhNubj)}(h **changes**h]hchanges}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubh (using }(hj^hhhNhNubh)}(hD:c:type:`enum cfg80211_nan_conf_changes `h]j,)}(hjzh]henum cfg80211_nan_conf_changes}(hj|hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjxubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJcfg80211_nan_conf_changesuh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj^ubh(); All other parameters must be ignored.}(hj^hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhj[ubah}(h]h ]h"]h$]h&]uh1jIhj?ubeh}(h]h ]h"]h$]h&]uh1j)hjZhMhj3ubj*)}(hX``nan_set_local_sched`` configure the local schedule for NAN. The schedule consists of an array of ``cfg80211_nan_channel`` and the schedule itself, in which each entry maps each time slot to the channel on which the radio should operate on. If the chandef of a NAN channel is not changed, the channel entry must also remain unchanged. It is the driver's responsibility to verify this. h](j0)}(h``nan_set_local_sched``h]j,)}(hjh]hnan_set_local_sched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hXiconfigure the local schedule for NAN. The schedule consists of an array of ``cfg80211_nan_channel`` and the schedule itself, in which each entry maps each time slot to the channel on which the radio should operate on. If the chandef of a NAN channel is not changed, the channel entry must also remain unchanged. It is the driver's responsibility to verify this.h](hKconfigure the local schedule for NAN. The schedule consists of an array of }(hjhhhNhNubj,)}(h``cfg80211_nan_channel``h]hcfg80211_nan_channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubhX and the schedule itself, in which each entry maps each time slot to the channel on which the radio should operate on. If the chandef of a NAN channel is not changed, the channel entry must also remain unchanged. It is the driver’s responsibility to verify this.}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hX``nan_set_peer_sched`` configure the peer schedule for NAN. The schedule consists of an array of ``cfg80211_nan_channel`` and the schedule itself, in which each entry maps each time slot to a channel on which the radio should operate on. In addition, it contains more peer's schedule information such as committed DW, etc. When updating an existing peer schedule, the full new schedule is provided - partial updates are not supported, and the new schedule completely replaces the previous one. h](j0)}(h``nan_set_peer_sched``h]j,)}(hjh]hnan_set_peer_sched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hXconfigure the peer schedule for NAN. The schedule consists of an array of ``cfg80211_nan_channel`` and the schedule itself, in which each entry maps each time slot to a channel on which the radio should operate on. In addition, it contains more peer's schedule information such as committed DW, etc. When updating an existing peer schedule, the full new schedule is provided - partial updates are not supported, and the new schedule completely replaces the previous one.h](hJconfigure the peer schedule for NAN. The schedule consists of an array of }(hjhhhNhNubj,)}(h``cfg80211_nan_channel``h]hcfg80211_nan_channel}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubhXv and the schedule itself, in which each entry maps each time slot to a channel on which the radio should operate on. In addition, it contains more peer’s schedule information such as committed DW, etc. When updating an existing peer schedule, the full new schedule is provided - partial updates are not supported, and the new schedule completely replaces the previous one.}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hO``set_multicast_to_unicast`` configure multicast to unicast conversion for BSS h](j0)}(h``set_multicast_to_unicast``h]j,)}(hjLh]hset_multicast_to_unicast}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjJubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjFubjJ)}(hhh]h)}(h1configure multicast to unicast conversion for BSSh]h1configure multicast to unicast conversion for BSS}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjahMhjbubah}(h]h ]h"]h$]h&]uh1jIhjFubeh}(h]h ]h"]h$]h&]uh1j)hjahMhj3ubj*)}(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](j0)}(h``get_txq_stats``h]j,)}(hjh]h get_txq_stats}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1j+hjubhG, 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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h ``set_pmk``h]j,)}(hjh]hset_pmk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hconfigure the PMK to be used for offloaded 802.1X 4-Way handshake. If not deleted through **del_pmk** the PMK remains valid until disconnect upon which the driver should clear it. (invoked with the wireless_dev mutex held)h](hZconfigure the PMK to be used for offloaded 802.1X 4-Way handshake. If not deleted through }(hjhhhNhNubj)}(h **del_pmk**h]hdel_pmk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhy the PMK remains valid until disconnect upon which the driver should clear it. (invoked with the wireless_dev mutex held)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hy``del_pmk`` delete the previously configured PMK for the given authenticator. (invoked with the wireless_dev mutex held) h](j0)}(h ``del_pmk``h]j,)}(hjh]hdel_pmk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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)}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj3ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj2hMhj3ubj*)}(hZ``external_auth`` indicates result of offloaded authentication processing from user space h](j0)}(h``external_auth``h]j,)}(hjWh]h external_auth}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjUubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjQubjJ)}(hhh]h)}(hGindicates result of offloaded authentication processing from user spaceh]hGindicates result of offloaded authentication processing from user space}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjmubah}(h]h ]h"]h$]h&]uh1jIhjQubeh}(h]h ]h"]h$]h&]uh1j)hjlhMhj3ubj*)}(h``tx_control_port`` TX a control port frame (EAPoL). The noencrypt parameter tells the driver that the frame should not be encrypted. h](j0)}(h``tx_control_port``h]j,)}(hjh]htx_control_port}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h``get_ftm_responder_stats`` Retrieve FTM responder statistics, if available. Statistics should be cumulative, currently no way to reset is provided. h](j0)}(h``get_ftm_responder_stats``h]j,)}(hjh]hget_ftm_responder_stats}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h1``start_pmsr`` start peer measurement (e.g. FTM) h](j0)}(h``start_pmsr``h]j,)}(hjh]h start_pmsr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(h!start peer measurement (e.g. FTM)h]h!start peer measurement (e.g. FTM)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h&``abort_pmsr`` abort peer measurement h](j0)}(h``abort_pmsr``h]j,)}(hj>h]h abort_pmsr}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj<ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj8ubjJ)}(hhh]h)}(habort peer measurementh]habort peer measurement}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShMhjTubah}(h]h ]h"]h$]h&]uh1jIhj8ubeh}(h]h ]h"]h$]h&]uh1j)hjShMhj3ubj*)}(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](j0)}(h``update_owe_info``h]j,)}(hjwh]hupdate_owe_info}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjuubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjqubjJ)}(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&]uh1jIhjqubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h|``probe_mesh_link`` Probe direct Mesh peer's link quality by sending data frame and overrule HWMP path selection algorithm. h](j0)}(h``probe_mesh_link``h]j,)}(hjh]hprobe_mesh_link}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hi``set_tid_config`` TID specific configuration, this can be peer or BSS specific This callback may sleep. h](j0)}(h``set_tid_config``h]j,)}(hjh]hset_tid_config}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hUTID specific configuration, this can be peer or BSS specific This callback may sleep.h]hUTID specific configuration, this can be peer or BSS specific This callback may sleep.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hq``reset_tid_config`` Reset TID specific configuration for the peer, for the given TIDs. This callback may sleep. h](j0)}(h``reset_tid_config``h]j,)}(hj%h]hreset_tid_config}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj#ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj:hMhj3ubj*)}(h6``set_sar_specs`` Update the SAR (TX power) settings. h](j0)}(h``set_sar_specs``h]j,)}(hj_h]h set_sar_specs}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj]ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjYubjJ)}(hhh]h)}(h#Update the SAR (TX power) settings.h]h#Update the SAR (TX power) settings.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjthMhjuubah}(h]h ]h"]h$]h&]uh1jIhjYubeh}(h]h ]h"]h$]h&]uh1j)hjthMhj3ubj*)}(h*``color_change`` Initiate a color change. h](j0)}(h``color_change``h]j,)}(hjh]h color_change}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hInitiate a color change.h]hInitiate a color change.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``set_fils_aad``h]j,)}(hjh]h set_fils_aad}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hSet FILS AAD data to the AP driver so that the driver can use those to decrypt (Re)Association Request and encrypt (Re)Association Response frame.h]hSet FILS AAD data to the AP driver so that the driver can use those to decrypt (Re)Association Request and encrypt (Re)Association Response frame.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(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](j0)}(h``set_radar_background``h]j,)}(hj h]hset_radar_background}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(hhh]h)}(hXConfigure dedicated offchannel chain available for radar/CAC detection on some hw. This chain can't be used to transmit or receive frames and it is bounded to a running wdev. Background radar/CAC detection allows to avoid the CAC downtime switching to a different channel during CAC detection on the selected radar channel. The caller is expected to set chandef pointer to NULL in order to disable background CAC/radar detection.h]hXConfigure dedicated offchannel chain available for radar/CAC detection on some hw. This chain can’t be used to transmit or receive frames and it is bounded to a running wdev. Background radar/CAC detection allows to avoid the CAC downtime switching to a different channel during CAC detection on the selected radar channel. The caller is expected to set chandef pointer to NULL in order to disable background CAC/radar detection.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj!ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hMhj3ubj*)}(h.``add_link_station`` Add a link to a station. h](j0)}(h``add_link_station``h]j,)}(hjEh]hadd_link_station}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjCubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj?ubjJ)}(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&]uh1jIhj?ubeh}(h]h ]h"]h$]h&]uh1j)hjZhMhj3ubj*)}(h1``mod_link_station`` Modify a link of a station. h](j0)}(h``mod_link_station``h]j,)}(hj~h]hmod_link_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj|ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjxubjJ)}(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&]uh1jIhjxubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h1``del_link_station`` Remove a link of a station. h](j0)}(h``del_link_station``h]j,)}(hjh]hdel_link_station}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(hF``set_hw_timestamp`` Enable/disable HW timestamping of TM/FTM frames. h](j0)}(h``set_hw_timestamp``h]j,)}(hjh]hset_hw_timestamp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h*``set_ttlm`` set the TID to link mapping. h](j0)}(h ``set_ttlm``h]j,)}(hj)h]hset_ttlm}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj'ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj#ubjJ)}(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&]uh1jIhj#ubeh}(h]h ]h"]h$]h&]uh1j)hj>hMhj3ubj*)}(hU``get_radio_mask`` get bitmask of radios in use. (invoked with the wiphy mutex held) h](j0)}(h``get_radio_mask``h]j,)}(hjbh]hget_radio_mask}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj`ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhj\ubjJ)}(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)}(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&]uh1jIhj\ubeh}(h]h ]h"]h$]h&]uh1j)hjwhMhj3ubj*)}(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](j0)}(h``assoc_ml_reconf``h]j,)}(hjh]hassoc_ml_reconf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubj*)}(h2``set_epcs`` Enable/Disable EPCS for station mode.h](j0)}(h ``set_epcs``h]j,)}(hjh]hset_epcs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjubjJ)}(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.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj3ubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMhjcchhubh)}(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.}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM8hjcchhubh)}(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.hhM;hjcchhubh)}(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.hhM>hjcchhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js"cfg80211_rx_mlme_mgmt (C function)c.cfg80211_rx_mlme_mgmthNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hNvoid cfg80211_rx_mlme_mgmt (struct net_device *dev, const u8 *buf, size_t len)h]j)}(hMvoid cfg80211_rx_mlme_mgmt(struct net_device *dev, const u8 *buf, size_t len)h](j)}(hvoidh]hvoid}(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjqhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMK ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjqhhhjhMK ubj)}(hcfg80211_rx_mlme_mgmth]j)}(hcfg80211_rx_mlme_mgmth]hcfg80211_rx_mlme_mgmt}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjqhhhjhMK ubj)}(h3(struct net_device *dev, const u8 *buf, size_t len)h](j%)}(hstruct net_device *devh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jf)}j^jsbc.cfg80211_rx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hdevh]hdev}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h const u8 *bufh](j)}(hjIh]hconst}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(h h]h }(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(hu8h]hu8}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjDmodnameN classnameNj j )}j ]jc.cfg80211_rx_mlme_mgmtasbuh1hhj ubj)}(h h]h }(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjz)}(hj}h]h*}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj ubj)}(hbufh]hbuf}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h size_t lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jc.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&]noemphjjuh1j$hjubeh}(h]h ]h"]h$]h&]jjuh1jhjqhhhjhMK ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjmhhhjhMK ubah}(h]jhah ](jjeh"]h$]h&]jj)jhuh1j|hjhMK hjjhhubj)}(hhh]h)}(h/notification of processed MLME management frameh]h/notification of processed MLME management frame}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMK hjhhubah}(h]h ]h"]h$]h&]uh1jhjjhhhjhMK ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjjjjjjuh1jwhhhjcchNhNubj)}(hX**Parameters** ``struct net_device *dev`` network device ``const u8 *buf`` authentication frame (header + body) ``size_t len`` length of the frame data **Description** This function is called whenever an authentication, disassociation or deauthentication frame has been received and processed in station mode. After being asked to authenticate via cfg80211_ops::auth() the driver must call either this function or cfg80211_auth_timeout(). After being asked to associate via cfg80211_ops::assoc() the driver must call either this function or cfg80211_auth_timeout(). While connected, the driver must calls this for received and processed disassociation and deauthentication frames. If the frame couldn't be used because it was unprotected, the driver must call the function cfg80211_rx_unprot_mlme_mgmt() instead. This function may sleep. The caller must hold the corresponding wdev's mutex.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMO hj ubj%)}(hhh](j*)}(h*``struct net_device *dev`` network device h](j0)}(h``struct net_device *dev``h]j,)}(hj.h]hstruct net_device *dev}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj,ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhML hj(ubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChML hjDubah}(h]h ]h"]h$]h&]uh1jIhj(ubeh}(h]h ]h"]h$]h&]uh1j)hjChML hj%ubj*)}(h7``const u8 *buf`` authentication frame (header + body) h](j0)}(h``const u8 *buf``h]j,)}(hjgh]h const u8 *buf}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjeubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMM hjaubjJ)}(hhh]h)}(h$authentication frame (header + body)h]h$authentication frame (header + body)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMM hj}ubah}(h]h ]h"]h$]h&]uh1jIhjaubeh}(h]h ]h"]h$]h&]uh1j)hj|hMM hj%ubj*)}(h(``size_t len`` length of the frame data h](j0)}(h``size_t len``h]j,)}(hjh]h size_t len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMN hjubjJ)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMN hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMN hj%ubeh}(h]h ]h"]h$]h&]uh1j$hj ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMP hj 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.hhMO hj ubh)}(hMThis function may sleep. The caller must hold the corresponding wdev's mutex.h]hOThis function may sleep. The caller must hold the corresponding wdev’s mutex.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMZ hj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js"cfg80211_auth_timeout (C function)c.cfg80211_auth_timeouthNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hCvoid cfg80211_auth_timeout (struct net_device *dev, const u8 *addr)h]j)}(hBvoid cfg80211_auth_timeout(struct net_device *dev, const u8 *addr)h](j)}(hvoidh]hvoid}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM` ubj)}(h h]h }(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+hhhj=hM` ubj)}(hcfg80211_auth_timeouth]j)}(hcfg80211_auth_timeouth]hcfg80211_auth_timeout}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLubah}(h]h ](jjeh"]h$]h&]jjuh1jhj+hhhj=hM` ubj)}(h((struct net_device *dev, const u8 *addr)h](j%)}(hstruct net_device *devh](j)}(hjh]hstruct}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubj)}(h h]h }(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jf)}j^jRsbc.cfg80211_auth_timeoutasbuh1hhjhubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjhubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjdubj%)}(hconst u8 *addrh](j)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_auth_timeoutasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(haddrh]haddr}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjdubeh}(h]h ]h"]h$]h&]jjuh1jhj+hhhj=hM` ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj'hhhj=hM` ubah}(h]j"ah ](jjeh"]h$]h&]jj)jhuh1j|hj=hM` hj$hhubj)}(hhh]h)}(h(notification of timed out authenticationh]h(notification of timed out authentication}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM` hj\hhubah}(h]h ]h"]h$]h&]uh1jhj$hhhj=hM` ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjwjjwjjjuh1jwhhhjcchNhNubj)}(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&]uh1jhjubah}(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`` network device h](j0)}(h``struct net_device *dev``h]j,)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMa hjubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMa hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMa hjubj*)}(hY``const u8 *addr`` The MAC address of the device with which the authentication timed out h](j0)}(h``const u8 *addr``h]j,)}(hjh]hconst u8 *addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMb hjubjJ)}(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&]uh1hhjhMb hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMb hjubeh}(h]h ]h"]h$]h&]uh1j$hj{ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMd hj{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.hhMc hj{ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js#cfg80211_rx_assoc_resp (C function)c.cfg80211_rx_assoc_resphNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hdvoid cfg80211_rx_assoc_resp (struct net_device *dev, const struct cfg80211_rx_assoc_resp_data *data)h]j)}(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.hhM ubj)}(h h]h }(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUhhhjghM ubj)}(hcfg80211_rx_assoc_resph]j)}(hcfg80211_rx_assoc_resph]hcfg80211_rx_assoc_resp}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvubah}(h]h ](jjeh"]h$]h&]jjuh1jhjUhhhjghM ubj)}(hH(struct net_device *dev, const struct cfg80211_rx_assoc_resp_data *data)h](j%)}(hstruct net_device *devh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jf)}j^j|sbc.cfg80211_rx_assoc_respasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h.const struct cfg80211_rx_assoc_resp_data *datah](j)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]hstruct}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(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&] refdomainj8reftypej^ reftargetjCmodnameN classnameNj j )}j ]jc.cfg80211_rx_assoc_respasbuh1hhjubj)}(h h]h }(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjmhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hdatah]hdata}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubeh}(h]h ]h"]h$]h&]jjuh1jhjUhhhjghM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjQhhhjghM ubah}(h]jLah ](jjeh"]h$]h&]jj)jhuh1j|hjghM hjNhhubj)}(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.hhM hjhhubah}(h]h ]h"]h$]h&]uh1jhjNhhhjghM ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjjjjjjuh1jwhhhjcchNhNubj)}(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&]uh1jhjubah}(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](j0)}(h``struct net_device *dev``h]j,)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h``const struct cfg80211_rx_assoc_resp_data *data`` association response data, :c:type:`struct cfg80211_rx_assoc_resp_data ` h](j0)}(h2``const struct cfg80211_rx_assoc_resp_data *data``h]j,)}(hjh]h.const struct cfg80211_rx_assoc_resp_data *data}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(heassociation response data, :c:type:`struct cfg80211_rx_assoc_resp_data `h](hassociation response data, }(hj7hhhNhNubh)}(hJ:c:type:`struct cfg80211_rx_assoc_resp_data `h]j,)}(hjAh]h"struct cfg80211_rx_assoc_resp_data}(hjChhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj?ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJcfg80211_rx_assoc_resp_datauh1hhj3hM hj7ubeh}(h]h ]h"]h$]h&]uh1hhj3hM hj4ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj3hM hjubeh}(h]h ]h"]h$]h&]uh1j$hjubh)}(h**Description**h]j)}(hjxh]h Description}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(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.hhM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js"cfg80211_tx_mlme_mgmt (C function)c.cfg80211_tx_mlme_mgmthNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(h^void cfg80211_tx_mlme_mgmt (struct net_device *dev, const u8 *buf, size_t len, bool reconnect)h]j)}(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.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hcfg80211_tx_mlme_mgmth]j)}(hcfg80211_tx_mlme_mgmth]hcfg80211_tx_mlme_mgmt}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubj)}(hC(struct net_device *dev, const u8 *buf, size_t len, bool reconnect)h](j%)}(hstruct net_device *devh](j)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetj)modnameN classnameNj j )}j ]jf)}j^jsbc.cfg80211_tx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hdevh]hdev}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h const u8 *bufh](j)}(hjIh]hconst}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jCc.cfg80211_tx_mlme_mgmtasbuh1hhjwubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjwubj)}(hbufh]hbuf}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h size_t lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jCc.cfg80211_tx_mlme_mgmtasbuh1hhjubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hlenh]hlen}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(hbool reconnecth](j)}(hboolh]hbool}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ubj)}(h h]h }(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ubj)}(h reconnecth]h reconnect}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhM hjhhubj)}(hhh]h)}(h1notification of transmitted deauth/disassoc frameh]h1notification of transmitted deauth/disassoc frame}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjvhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjjjjjjuh1jwhhhjcchNhNubj)}(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&]uh1jhjubah}(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](j0)}(h``struct net_device *dev``h]j,)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h/``const u8 *buf`` 802.11 frame (header + body) h](j0)}(h``const u8 *buf``h]j,)}(hjh]h const u8 *buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h802.11 frame (header + body)h]h802.11 frame (header + body)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h(``size_t len`` length of the frame data h](j0)}(h``size_t len``h]j,)}(hj,h]h size_t len}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj*ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj&ubjJ)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhM hjBubah}(h]h ]h"]h$]h&]uh1jIhj&ubeh}(h]h ]h"]h$]h&]uh1j)hjAhM hjubj*)}(hR``bool reconnect`` immediate reconnect is desired (include the nl80211 attribute) h](j0)}(h``bool reconnect``h]j,)}(hjeh]hbool reconnect}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjcubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hj_ubjJ)}(hhh]h)}(h>immediate reconnect is desired (include the nl80211 attribute)h]h>immediate reconnect is desired (include the nl80211 attribute)}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhM hj{ubah}(h]h ]h"]h$]h&]uh1jIhj_ubeh}(h]h ]h"]h$]h&]uh1j)hjzhM hjubeh}(h]h ]h"]h$]h&]uh1j$hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubh)}(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.hhM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js)cfg80211_michael_mic_failure (C function)c.cfg80211_michael_mic_failurehNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(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)}(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.hhM ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM ubj)}(hcfg80211_michael_mic_failureh]j)}(hcfg80211_michael_mic_failureh]hcfg80211_michael_mic_failure}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubj)}(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](j)}(hjh]hstruct}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hj/hhhNhNubah}(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&] refdomainj8reftypej^ reftargetjBmodnameN classnameNj j )}j ]jf)}j^jsbc.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hdevh]hdev}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(hconst u8 *addrh](j)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j\c.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(haddrh]haddr}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(henum nl80211_key_type key_typeh](j)}(hjh]henum}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hnl80211_key_typeh]hnl80211_key_type}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj$modnameN classnameNj j )}j ]j\c.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hkey_typeh]hkey_type}(hjNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h int key_idh](j)}(hinth]hint}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubj)}(h h]h }(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubj)}(hkey_idh]hkey_id}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h const u8 *tsch](j)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j\c.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(htsch]htsc}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j\c.cfg80211_michael_mic_failureasbuh1hhjubj)}(h h]h }(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhM hjhhubj)}(hhh]h)}(h*notification of Michael MIC failure (TKIP)h]h*notification of Michael MIC failure (TKIP)}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjbhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j8functioneh"]h$]h&]jj8jj}jj}jjjuh1jwhhhjcchNhNubj)}(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&]uh1jhjubah}(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](j0)}(h``struct net_device *dev``h]j,)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h7``const u8 *addr`` The source MAC address of the frame h](j0)}(h``const u8 *addr``h]j,)}(hjh]hconst u8 *addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h#The source MAC address of the frameh]h#The source MAC address of the frame}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(hM``enum nl80211_key_type key_type`` The key type that the received frame used h](j0)}(h"``enum nl80211_key_type key_type``h]j,)}(hjh]henum nl80211_key_type key_type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(h)The key type that the received frame usedh]h)The key type that the received frame used}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-hM hj.ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj-hM hjubj*)}(h<``int key_id`` Key identifier (0..3). Can be -1 if missing. h](j0)}(h``int key_id``h]j,)}(hjQh]h int key_id}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjOubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjKubjJ)}(hhh]h)}(h,Key identifier (0..3). Can be -1 if missing.h]h,Key identifier (0..3). Can be -1 if missing.}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhM hjgubah}(h]h ]h"]h$]h&]uh1jIhjKubeh}(h]h ]h"]h$]h&]uh1j)hjfhM hjubj*)}(hW``const u8 *tsc`` The TSC value of the frame that generated the MIC failure (6 octets) h](j0)}(h``const u8 *tsc``h]j,)}(hjh]h const u8 *tsc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(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&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubj*)}(h``gfp_t gfp`` allocation flags h](j0)}(h ``gfp_t gfp``h]j,)}(hjh]h gfp_t gfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjubeh}(h]h ]h"]h$]h&]uh1j$hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubh)}(hThis function is called whenever the local MAC detects a MIC failure in a received frame. This matches with MLME-MICHAELMICFAILURE.indication() primitive.h]hThis function is called whenever the local MAC detects a MIC failure in a received frame. This matches with MLME-MICHAELMICFAILURE.indication() primitive.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js!cfg80211_ibss_joined (C function)c.cfg80211_ibss_joinedhNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hqvoid cfg80211_ibss_joined (struct net_device *dev, const u8 *bssid, struct ieee80211_channel *channel, gfp_t gfp)h]j)}(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.hhM ubj)}(h h]h }(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?hhhjQhM ubj)}(hcfg80211_ibss_joinedh]j)}(hcfg80211_ibss_joinedh]hcfg80211_ibss_joined}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj?hhhjQhM ubj)}(hW(struct net_device *dev, const u8 *bssid, struct ieee80211_channel *channel, gfp_t gfp)h](j%)}(hstruct net_device *devh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj|ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj|ubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jf)}j^jfsbc.cfg80211_ibss_joinedasbuh1hhj|ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj|ubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj|ubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj|ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjxubj%)}(hconst u8 *bssidh](j)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_ibss_joinedasbuh1hhjubj)}(h h]h }(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hj<hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hbssidh]hbssid}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjxubj%)}(h!struct ieee80211_channel *channelh](j)}(hjh]hstruct}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubj)}(h h]h }(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubh)}(hhh]j)}(hieee80211_channelh]hieee80211_channel}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_ibss_joinedasbuh1hhj^ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj^ubj)}(hchannelh]hchannel}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjxubj%)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_ibss_joinedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjxubeh}(h]h ]h"]h$]h&]jjuh1jhj?hhhjQhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj;hhhjQhM ubah}(h]j6ah ](jjeh"]h$]h&]jj)jhuh1j|hjQhM hj8hhubj)}(hhh]h)}(h*notify cfg80211 that device joined an IBSSh]h*notify cfg80211 that device joined an IBSS}(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&]uh1jhj8hhhjQhM ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjCjjCjjjuh1jwhhhjcchNhNubj)}(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&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjGubj%)}(hhh](j*)}(h*``struct net_device *dev`` network device h](j0)}(h``struct net_device *dev``h]j,)}(hjlh]hstruct net_device *dev}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjfubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjfubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjcubj*)}(h1``const u8 *bssid`` the BSSID of the IBSS joined h](j0)}(h``const u8 *bssid``h]j,)}(hjh]hconst u8 *bssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hthe BSSID of the IBSS joinedh]hthe BSSID of the IBSS joined}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjcubj*)}(hE``struct ieee80211_channel *channel`` the channel of the IBSS joined h](j0)}(h%``struct ieee80211_channel *channel``h]j,)}(hjh]h!struct ieee80211_channel *channel}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hthe channel of the IBSS joinedh]hthe channel of the IBSS joined}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM hjcubj*)}(h``gfp_t gfp`` allocation flags h](j0)}(h ``gfp_t gfp``h]j,)}(hjh]h gfp_t gfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjubjJ)}(hhh]h)}(hallocation flagsh]hallocation flags}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,hM hj-ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj,hM hjcubeh}(h]h ]h"]h$]h&]uh1j$hjGubh)}(h**Description**h]j)}(hjRh]h Description}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjGubh)}(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.}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM hjGubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js'cfg80211_connect_resp_params (C struct)c.cfg80211_connect_resp_paramshNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hcfg80211_connect_resp_paramsh]j)}(h#struct cfg80211_connect_resp_paramsh](j)}(hjh]hstruct}(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_resp_paramsh]j)}(hjh]hcfg80211_connect_resp_params}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhM hjhhubj)}(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.hhM]"hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](j8structeh"]h$]h&]jj8jjjjjjjuh1jwhhhjcchNhNubj)}(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&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMa"hjubj: )}(hXstruct cfg80211_connect_resp_params { int status; const u8 *req_ie; size_t req_ie_len; const u8 *resp_ie; size_t resp_ie_len; struct cfg80211_fils_resp_params fils; enum nl80211_timeout_reason timeout_reason; const u8 *ap_mld_addr; u16 valid_links; struct { const u8 *addr; const u8 *bssid; struct cfg80211_bss *bss; u16 status; } links[IEEE80211_MLD_MAX_NUM_LINKS]; };h]hXstruct cfg80211_connect_resp_params { int status; const u8 *req_ie; size_t req_ie_len; const u8 *resp_ie; size_t resp_ie_len; struct cfg80211_fils_resp_params fils; enum nl80211_timeout_reason timeout_reason; const u8 *ap_mld_addr; u16 valid_links; struct { const u8 *addr; const u8 *bssid; struct cfg80211_bss *bss; u16 status; } links[IEEE80211_MLD_MAX_NUM_LINKS]; };}hjsbah}(h]h ]h"]h$]h&]jjuh1j9 h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMc"hjubh)}(h **Members**h]j)}(hj'h]hMembers}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMu"hjubj%)}(hhh](j*)}(hX``status`` Status code, ``WLAN_STATUS_SUCCESS`` for successful connection, use ``WLAN_STATUS_UNSPECIFIED_FAILURE`` if your device cannot give you the real status code for failures. If this call is used to report a failure due to a timeout (e.g., not receiving an Authentication frame from the AP) instead of an explicit rejection by the AP, -1 is used to indicate that this is a failure, but without a status code. **timeout_reason** is used to report the reason for the timeout in that case. h](j0)}(h ``status``h]j,)}(hjFh]hstatus}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjDubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMf"hj@ubjJ)}(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}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj_ubh for successful connection, use }(hj_hhhNhNubj,)}(h#``WLAN_STATUS_UNSPECIFIED_FAILURE``h]hWLAN_STATUS_UNSPECIFIED_FAILURE}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj_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}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_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&]uh1jIhj@ubeh}(h]h ]h"]h$]h&]uh1j)hj[hMf"hj=ubj*)}(h5``req_ie`` Association request IEs (may be ``NULL``) h](j0)}(h ``req_ie``h]j,)}(hjh]hreq_ie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMg"hjubjJ)}(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&]uh1j+hjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMg"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMg"hj=ubj*)}(h.``req_ie_len`` Association request IEs length h](j0)}(h``req_ie_len``h]j,)}(hjh]h req_ie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMh"hjubjJ)}(hhh]h)}(hAssociation request IEs lengthh]hAssociation request IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMh"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMh"hj=ubj*)}(h7``resp_ie`` Association response IEs (may be ``NULL``) h](j0)}(h ``resp_ie``h]j,)}(hj:h]hresp_ie}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj8ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMi"hj4ubjJ)}(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&]uh1j+hjSubh)}(hjShhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjOhMi"hjPubah}(h]h ]h"]h$]h&]uh1jIhj4ubeh}(h]h ]h"]h$]h&]uh1j)hjOhMi"hj=ubj*)}(h0``resp_ie_len`` Association response IEs length h](j0)}(h``resp_ie_len``h]j,)}(hjh]h resp_ie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMj"hjubjJ)}(hhh]h)}(hAssociation response IEs lengthh]hAssociation response IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMj"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMj"hj=ubj*)}(h.``fils`` FILS connection response parameters. h](j0)}(h``fils``h]j,)}(hjh]hfils}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMk"hjubjJ)}(hhh]h)}(h$FILS connection response parameters.h]h$FILS connection response parameters.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMk"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMk"hj=ubj*)}(hX``timeout_reason`` Reason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. ``NL80211_TIMEOUT_UNSPECIFIED`` is used when the timeout reason is not known. This value is used only if **status** < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (**status** >= 0). h](j0)}(h``timeout_reason``h]j,)}(hjh]htimeout_reason}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMq"hjubjJ)}(hhh]h)}(hXReason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. ``NL80211_TIMEOUT_UNSPECIFIED`` is used when the timeout reason is not known. This value is used only if **status** < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (**status** >= 0).h](hReason for connection timeout. This is used when the connection fails due to a timeout instead of an explicit rejection from the AP. }(hjhhhNhNubj,)}(h``NL80211_TIMEOUT_UNSPECIFIED``h]hNL80211_TIMEOUT_UNSPECIFIED}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubhJ is used when the timeout reason is not known. This value is used only if }(hjhhhNhNubj)}(h **status**h]hstatus}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh < 0 to indicate that the failure is due to a timeout and not due to explicit rejection by the AP. This value is ignored in other cases (}(hjhhhNhNubj)}(h **status**h]hstatus}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh >= 0).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMl"hj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hMq"hj=ubj*)}(hO``ap_mld_addr`` For MLO connection, MLD address of the AP. Otherwise ``NULL``. h](j0)}(h``ap_mld_addr``h]j,)}(hjgh]h ap_mld_addr}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjeubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMt"hjaubjJ)}(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&]uh1j+hjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj|hMt"hj}ubah}(h]h ]h"]h$]h&]uh1jIhjaubeh}(h]h ]h"]h$]h&]uh1j)hj|hMt"hj=ubj*)}(hT``valid_links`` For MLO connection, BIT mask of the valid link ids. Otherwise zero. h](j0)}(h``valid_links``h]j,)}(hjh]h valid_links}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMs"hjubjJ)}(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.hhMr"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMs"hj=ubj*)}(h``links`` For MLO connection, contains link info for the valid links indicated using **valid_links**. For non-MLO connection, links[0] contains the connected AP info. h](j0)}(h ``links``h]j,)}(hjh]hlinks}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMw"hjubjJ)}(hhh]h)}(hFor MLO connection, contains link info for the valid links indicated using **valid_links**. For non-MLO connection, links[0] contains the connected AP info.h](hKFor MLO connection, contains link info for the valid links indicated using }(hjhhhNhNubj)}(h**valid_links**h]h valid_links}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhB. For non-MLO connection, links[0] contains the connected AP info.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMu"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhMw"hj=ubj*)}(hT``links.addr`` For MLO connection, MAC address of the STA link. Otherwise ``NULL``. h](j0)}(h``links.addr``h]j,)}(hj8h]h links.addr}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMy"hj2ubjJ)}(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&]uh1j+hjQubh.}(hjQhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMx"hjNubah}(h]h ]h"]h$]h&]uh1jIhj2ubeh}(h]h ]h"]h$]h&]uh1j)hjMhMy"hj=ubj*)}(h``links.bssid`` For MLO connection, MAC address of the AP link. For non-MLO connection, links[0].bssid points to the BSSID of the AP (may be ``NULL``). h](j0)}(h``links.bssid``h]j,)}(hjh]h links.bssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM{"hj~ubjJ)}(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&]uh1j+hjubh).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMz"hjubah}(h]h ]h"]h$]h&]uh1jIhj~ubeh}(h]h ]h"]h$]h&]uh1j)hjhM{"hj=ubj*)}(hX``links.bss`` For MLO connection, entry of bss to which STA link is connected. For non-MLO connection, links[0].bss points to entry of bss to which STA is connected. It can be obtained through cfg80211_get_bss() (may be ``NULL``). It is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified. h](j0)}(h ``links.bss``h]j,)}(hjh]h links.bss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubjJ)}(hhh]h)}(hXFor MLO connection, entry of bss to which STA link is connected. For non-MLO connection, links[0].bss points to entry of bss to which STA is connected. It can be obtained through cfg80211_get_bss() (may be ``NULL``). It is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among **bssid** and **bss** needs to be specified.h](hFor MLO connection, entry of bss to which STA link is connected. For non-MLO connection, links[0].bss points to entry of bss to which STA is connected. It can be obtained through cfg80211_get_bss() (may be }(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubhX). It is recommended to store the bss from the connect_request and hold a reference to it and return through this param to avoid a warning if the bss is expired during the connection, esp. for those drivers implementing connect op. Only one parameter among }(hjhhhNhNubj)}(h **bssid**h]hbssid}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh and }(hjhhhNhNubj)}(h**bss**h]hbss}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh needs to be specified.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM|"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM"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](j0)}(h``links.status``h]j,)}(hj@ h]h links.status}(hjB hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj> ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj: ubjJ)}(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 }(hjY hhhNhNubj,)}(h``WLAN_STATUS_SUCCESS``h]hWLAN_STATUS_SUCCESS}(hja hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjY ubh* for a given link, it must also be in the }(hjY hhhNhNubj)}(h**valid_links**h]h valid_links}(hjs hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjY ubh; bitmap and may have a BSS pointer (which is then released)}(hjY hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjV ubah}(h]h ]h"]h$]h&]uh1jIhj: ubeh}(h]h ]h"]h$]h&]uh1j)hjU hM"hj=ubeh}(h]h ]h"]h$]h&]uh1j$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js"cfg80211_connect_done (C function)c.cfg80211_connect_donehNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hkvoid cfg80211_connect_done (struct net_device *dev, struct cfg80211_connect_resp_params *params, gfp_t gfp)h]j)}(hjvoid cfg80211_connect_done(struct net_device *dev, struct cfg80211_connect_resp_params *params, gfp_t gfp)h](j)}(hvoidh]hvoid}(hj hhhNhNubah}(h]h ]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_connect_doneh]j)}(hcfg80211_connect_doneh]hcfg80211_connect_done}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj hhhj hM"ubj)}(hP(struct net_device *dev, struct cfg80211_connect_resp_params *params, gfp_t gfp)h](j%)}(hstruct net_device *devh](j)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(h net_deviceh]h net_device}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj modnameN classnameNj j )}j ]jf)}j^j sbc.cfg80211_connect_doneasbuh1hhj ubj)}(h h]h }(hj9 hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjz)}(hj}h]h*}(hjG hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj ubj)}(hdevh]hdev}(hjT hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubj%)}(h+struct cfg80211_connect_resp_params *paramsh](j)}(hjh]hstruct}(hjm hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhji ubj)}(h h]h }(hjz hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhji ubh)}(hhh]j)}(hcfg80211_connect_resp_paramsh]hcfg80211_connect_resp_params}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj modnameN classnameNj j )}j ]j5 c.cfg80211_connect_doneasbuh1hhji ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhji ubjz)}(hj}h]h*}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhji ubj)}(hparamsh]hparams}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhji ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj 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&] refdomainj8reftypej^ reftargetj modnameN classnameNj j )}j ]j5 c.cfg80211_connect_doneasbuh1hhj 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&]noemphjjuh1j$hj ubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhj hM"ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj hhhj hM"ubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1j|hj hM"hj hhubj)}(hhh]h)}(h$notify cfg80211 of connection resulth]h$notify cfg80211 of connection result}(hj6 hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj3 hhubah}(h]h ]h"]h$]h&]uh1jhj hhhj hM"ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjN jjN jjjuh1jwhhhjcchNhNubj)}(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)}(hjX h]h Parameters}(hjZ hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjV ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjR ubj%)}(hhh](j*)}(h*``struct net_device *dev`` network device h](j0)}(h``struct net_device *dev``h]j,)}(hjw h]hstruct net_device *dev}(hjy hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hju ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjq ubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM"hj ubah}(h]h ]h"]h$]h&]uh1jIhjq ubeh}(h]h ]h"]h$]h&]uh1j)hj hM"hjn ubj*)}(hO``struct cfg80211_connect_resp_params *params`` connection response parameters h](j0)}(h/``struct cfg80211_connect_resp_params *params``h]j,)}(hj h]h+struct cfg80211_connect_resp_params *params}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj ubjJ)}(hhh]h)}(hconnection response parametersh]hconnection response parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM"hj ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj hM"hjn ubj*)}(h``gfp_t gfp`` allocation flags h](j0)}(h ``gfp_t gfp``h]j,)}(hj h]h gfp_t gfp}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj ubjJ)}(hhh]h)}(hallocation flagsh]hallocation flags}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM"hj ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj hM"hjn ubeh}(h]h ]h"]h$]h&]uh1j$hjR ubh)}(h**Description**h]j)}(hj$ h]h Description}(hj& hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj" ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjR ubh)}(hXIt should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_bss(), but takes a structure pointer for connection response parameters. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h]hXIt should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_bss(), but takes a structure pointer for connection response parameters. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.}(hj: hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjR ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js!cfg80211_connect_bss (C function)c.cfg80211_connect_bsshNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(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)}(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}(hji hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhje hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"ubj)}(h h]h }(hjx hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhje hhhjw hM"ubj)}(hcfg80211_connect_bssh]j)}(hcfg80211_connect_bssh]hcfg80211_connect_bss}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jhje hhhjw hM"ubj)}(h(struct net_device *dev, const u8 *bssid, struct cfg80211_bss *bss, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, int status, gfp_t gfp, enum nl80211_timeout_reason timeout_reason)h](j%)}(hstruct net_device *devh](j)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(h net_deviceh]h net_device}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj modnameN classnameNj j )}j ]jf)}j^j sbc.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjz)}(hj}h]h*}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj ubj)}(hdevh]hdev}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubj%)}(hconst u8 *bssidh](j)}(hjIh]hconst}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj 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&] refdomainj8reftypej^ reftargetj8 modnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hjT hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjz)}(hj}h]h*}(hjb hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj ubj)}(hbssidh]hbssid}(hjo hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubj%)}(hstruct cfg80211_bss *bssh](j)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(h cfg80211_bssh]h cfg80211_bss}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj modnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjz)}(hj}h]h*}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj ubj)}(hbssh]hbss}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubj%)}(hconst u8 *req_ieh](j)}(hjIh]hconst}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(hu8h]hu8}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhj ubj)}(h h]h }(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjz)}(hj}h]h*}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj ubj)}(hreq_ieh]hreq_ie}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubj%)}(hsize_t req_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmmodnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhjdubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdubj)}(h req_ie_lenh]h req_ie_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubj%)}(hconst u8 *resp_ieh](j)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hresp_ieh]hresp_ie}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubj%)}(hsize_t resp_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj%modnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhjubj)}(h h]h }(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h resp_ie_lenh]h resp_ie_len}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubj%)}(h int statush](j)}(hinth]hint}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdubj)}(h h]h }(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdubj)}(hstatush]hstatus}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubj%)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubj%)}(h*enum nl80211_timeout_reason timeout_reasonh](j)}(hjh]henum}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hnl80211_timeout_reasonh]hnl80211_timeout_reason}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j c.cfg80211_connect_bssasbuh1hhjubj)}(h h]h }(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(htimeout_reasonh]htimeout_reason}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubeh}(h]h ]h"]h$]h&]jjuh1jhje hhhjw hM"ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhja hhhjw hM"ubah}(h]j\ ah ](jjeh"]h$]h&]jj)jhuh1j|hjw hM"hj^ hhubj)}(hhh]h)}(h$notify cfg80211 of connection resulth]h$notify cfg80211 of connection result}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjVhhubah}(h]h ]h"]h$]h&]uh1jhj^ hhhjw hM"ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjqjjqjjjuh1jwhhhjcchNhNubj)}(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&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjuubj%)}(hhh](j*)}(h*``struct net_device *dev`` network device h](j0)}(h``struct net_device *dev``h]j,)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjubj*)}(h(``const u8 *bssid`` the BSSID of the AP h](j0)}(h``const u8 *bssid``h]j,)}(hjh]hconst u8 *bssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjubj*)}(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](j0)}(h``struct cfg80211_bss *bss``h]j,)}(hj h]hstruct cfg80211_bss *bss}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubjJ)}(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 }(hj%hhhNhNubj,)}(h``NULL``h]hNULL}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj%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 }(hj%hhhNhNubj)}(h **bssid**h]hbssid}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubh and }(hj%hhhNhNubj)}(h**bss**h]hbss}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%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.hhM"hj"ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj!hM"hjubj*)}(hA``const u8 *req_ie`` association request IEs (maybe be ``NULL``) h](j0)}(h``const u8 *req_ie``h]j,)}(hj|h]hconst u8 *req_ie}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjzubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjvubjJ)}(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&]uh1j+hjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1jIhjvubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjubj*)}(h5``size_t req_ie_len`` association request IEs length h](j0)}(h``size_t req_ie_len``h]j,)}(hjh]hsize_t req_ie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubjJ)}(hhh]h)}(hassociation request IEs lengthh]hassociation request IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjubj*)}(hA``const u8 *resp_ie`` association response IEs (may be ``NULL``) h](j0)}(h``const u8 *resp_ie``h]j,)}(hjh]hconst u8 *resp_ie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubjJ)}(hhh]h)}(h*association response IEs (may be ``NULL``)h](h!association response IEs (may be }(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjubj*)}(h1``size_t resp_ie_len`` assoc response IEs length h](j0)}(h``size_t resp_ie_len``h]j,)}(hjKh]hsize_t resp_ie_len}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjIubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjEubjJ)}(hhh]h)}(hassoc response IEs lengthh]hassoc response IEs length}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hM"hjaubah}(h]h ]h"]h$]h&]uh1jIhjEubeh}(h]h ]h"]h$]h&]uh1j)hj`hM"hjubj*)}(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](j0)}(h``int status``h]j,)}(hjh]h int status}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj~ubjJ)}(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&]uh1j+hjubh for successful connection, use }(hjhhhNhNubj,)}(h#``WLAN_STATUS_UNSPECIFIED_FAILURE``h]hWLAN_STATUS_UNSPECIFIED_FAILURE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubhX- 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&]uh1jhjubh; is used to report the reason for the timeout in that case.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubah}(h]h ]h"]h$]h&]uh1jIhj~ubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjubj*)}(h``gfp_t gfp`` allocation flags h](j0)}(h ``gfp_t gfp``h]j,)}(hjh]h gfp_t gfp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubjJ)}(hhh]h)}(hallocation flagsh]hallocation flags}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM"hj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj hM"hjubj*)}(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](j0)}(h.``enum nl80211_timeout_reason timeout_reason``h]j,)}(hj-h]h*enum nl80211_timeout_reason timeout_reason}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj+ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj'ubjJ)}(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&]uh1j+hjFubhJ is used when the timeout reason is not known. This value is used only if }(hjFhhhNhNubj)}(h **status**h]hstatus}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubh < 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}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubh >= 0).}(hjFhhhNhNubeh}(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&]uh1jIhj'ubeh}(h]h ]h"]h$]h&]uh1j)hjBhM"hjubeh}(h]h ]h"]h$]h&]uh1j$hjuubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjuubh)}(hXIt should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_result(), but with the option of identifying the exact bss entry for the connection. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.h]hXIt should be called by the underlying driver once execution of the connection request from connect() has been completed. This is similar to cfg80211_connect_result(), but with the option of identifying the exact bss entry for the connection. Only one of the functions among cfg80211_connect_bss(), cfg80211_connect_result(), cfg80211_connect_timeout(), and cfg80211_connect_done() should be called.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjuubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js$cfg80211_connect_result (C function)c.cfg80211_connect_resulthNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(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)}(hvoid cfg80211_connect_result(struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, u16 status, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM"ubj)}(hcfg80211_connect_resulth]j)}(hcfg80211_connect_resulth]hcfg80211_connect_result}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM"ubj)}(h(struct net_device *dev, const u8 *bssid, const u8 *req_ie, size_t req_ie_len, const u8 *resp_ie, size_t resp_ie_len, u16 status, gfp_t gfp)h](j%)}(hstruct net_device *devh](j)}(hjh]hstruct}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hj.hhhNhNubah}(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&] refdomainj8reftypej^ reftargetjAmodnameN classnameNj j )}j ]jf)}j^jsbc.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjmhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hdevh]hdev}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(hconst u8 *bssidh](j)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j[c.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hbssidh]hbssid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(hconst u8 *req_ieh](j)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetj#modnameN classnameNj j )}j ]j[c.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hreq_ieh]hreq_ie}(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(hsize_t req_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjxmodnameN classnameNj j )}j ]j[c.cfg80211_connect_resultasbuh1hhjoubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoubj)}(h req_ie_lenh]h req_ie_len}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(hconst u8 *resp_ieh](j)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j[c.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hresp_ieh]hresp_ie}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(hsize_t resp_ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj0modnameN classnameNj j )}j ]j[c.cfg80211_connect_resultasbuh1hhj'ubj)}(h h]h }(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubj)}(h resp_ie_lenh]h resp_ie_len}(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h u16 statush](h)}(hhh]j)}(hu16h]hu16}(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjxmodnameN classnameNj j )}j ]j[c.cfg80211_connect_resultasbuh1hhjoubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoubj)}(hstatush]hstatus}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j[c.cfg80211_connect_resultasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM"ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM"ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhM"hjhhubj)}(hhh]h)}(h$notify cfg80211 of connection resulth]h$notify cfg80211 of connection result}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM"ubeh}(h]h ](j8functioneh"]h$]h&]jj8jj,jj,jjjuh1jwhhhjcchNhNubj)}(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)}(hj6h]h Parameters}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj0ubj%)}(hhh](j*)}(h*``struct net_device *dev`` network device h](j0)}(h``struct net_device *dev``h]j,)}(hjUh]hstruct net_device *dev}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjSubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjOubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjhM"hjkubah}(h]h ]h"]h$]h&]uh1jIhjOubeh}(h]h ]h"]h$]h&]uh1j)hjjhM"hjLubj*)}(h(``const u8 *bssid`` the BSSID of the AP h](j0)}(h``const u8 *bssid``h]j,)}(hjh]hconst u8 *bssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjLubj*)}(hA``const u8 *req_ie`` association request IEs (maybe be ``NULL``) h](j0)}(h``const u8 *req_ie``h]j,)}(hjh]hconst u8 *req_ie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubjJ)}(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&]uh1j+hjubh)}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjLubj*)}(h5``size_t req_ie_len`` association request IEs length h](j0)}(h``size_t req_ie_len``h]j,)}(hjh]hsize_t req_ie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj ubjJ)}(hhh]h)}(hassociation request IEs lengthh]hassociation request IEs length}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hM"hj(ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj'hM"hjLubj*)}(hA``const u8 *resp_ie`` association response IEs (may be ``NULL``) h](j0)}(h``const u8 *resp_ie``h]j,)}(hjKh]hconst u8 *resp_ie}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjIubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjEubjJ)}(hhh]h)}(h*association response IEs (may be ``NULL``)h](h!association response IEs (may be }(hjdhhhNhNubj,)}(h``NULL``h]hNULL}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjdubh)}(hjdhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj`hM"hjaubah}(h]h ]h"]h$]h&]uh1jIhjEubeh}(h]h ]h"]h$]h&]uh1j)hj`hM"hjLubj*)}(h1``size_t resp_ie_len`` assoc response IEs length h](j0)}(h``size_t resp_ie_len``h]j,)}(hjh]hsize_t resp_ie_len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubjJ)}(hhh]h)}(hassoc response IEs lengthh]hassoc response IEs length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM"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](j0)}(h``u16 status``h]j,)}(hjh]h u16 status}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubjJ)}(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&]uh1j+hjubh for successful connection, use }(hjhhhNhNubj,)}(h#``WLAN_STATUS_UNSPECIFIED_FAILURE``h]hWLAN_STATUS_UNSPECIFIED_FAILURE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubhB if your device cannot give you the real status code for failures.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjLubj*)}(h``gfp_t gfp`` allocation flags h](j0)}(h ``gfp_t gfp``h]j,)}(hj-h]h gfp_t gfp}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj+ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj'ubjJ)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhM"hjCubah}(h]h ]h"]h$]h&]uh1jIhj'ubeh}(h]h ]h"]h$]h&]uh1j)hjBhM"hjLubeh}(h]h ]h"]h$]h&]uh1j$hj0ubh)}(h**Description**h]j)}(hjhh]h Description}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM"hj0ubh)}(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.}(hj~hhhNhNubah}(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&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js%cfg80211_connect_timeout (C function)c.cfg80211_connect_timeouthNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(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)}(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](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetj modnameN classnameNj j )}j ]jf)}j^jsbc.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hdevh]hdev}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(hconst u8 *bssidh](j)}(hjIh]hconst}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubj)}(h h]h }(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubh)}(hhh]j)}(hu8h]hu8}(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj|modnameN classnameNj j )}j ]j$c.cfg80211_connect_timeoutasbuh1hhjXubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjXubj)}(hbssidh]hbssid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(hconst u8 *req_ieh](j)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j$c.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hreq_ieh]hreq_ie}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(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&] refdomainj8reftypej^ reftargetjAmodnameN classnameNj j )}j ]j$c.cfg80211_connect_timeoutasbuh1hhj8ubj)}(h h]h }(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubj)}(h req_ie_lenh]h req_ie_len}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j$c.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&]noemphjjuh1j$hjubj%)}(h*enum nl80211_timeout_reason timeout_reasonh](j)}(hjh]henum}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hnl80211_timeout_reasonh]hnl80211_timeout_reason}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]j$c.cfg80211_connect_timeoutasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(htimeout_reasonh]htimeout_reason}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM#ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM#ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhM#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 ](j8functioneh"]h$]h&]jj8jjXjjXjjjuh1jwhhhjcchNhNubj)}(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)}(hjbh]h Parameters}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM #hj\ubj%)}(hhh](j*)}(h*``struct net_device *dev`` network device h](j0)}(h``struct net_device *dev``h]j,)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM #hj{ubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM #hjubah}(h]h ]h"]h$]h&]uh1jIhj{ubeh}(h]h ]h"]h$]h&]uh1j)hjhM #hjxubj*)}(h(``const u8 *bssid`` the BSSID of the AP h](j0)}(h``const u8 *bssid``h]j,)}(hjh]hconst u8 *bssid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM #hjubjJ)}(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&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM #hjxubj*)}(hA``const u8 *req_ie`` association request IEs (maybe be ``NULL``) h](j0)}(h``const u8 *req_ie``h]j,)}(hjh]hconst u8 *req_ie}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM #hjubjJ)}(hhh]h)}(h+association request IEs (maybe be ``NULL``)h](h"association request IEs (maybe be }(hj hhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubh)}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM #hj ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM #hjxubj*)}(h5``size_t req_ie_len`` association request IEs length h](j0)}(h``size_t req_ie_len``h]j,)}(hj>h]hsize_t req_ie_len}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj<ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM #hj8ubjJ)}(hhh]h)}(hassociation request IEs lengthh]hassociation request IEs length}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShM #hjTubah}(h]h ]h"]h$]h&]uh1jIhj8ubeh}(h]h ]h"]h$]h&]uh1j)hjShM #hjxubj*)}(h``gfp_t gfp`` allocation flags h](j0)}(h ``gfp_t gfp``h]j,)}(hjwh]h gfp_t gfp}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjuubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hjqubjJ)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM#hjubah}(h]h ]h"]h$]h&]uh1jIhjqubeh}(h]h ]h"]h$]h&]uh1j)hjhM#hjxubj*)}(hN``enum nl80211_timeout_reason timeout_reason`` reason for connection timeout. h](j0)}(h.``enum nl80211_timeout_reason timeout_reason``h]j,)}(hjh]h*enum nl80211_timeout_reason timeout_reason}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hjubjJ)}(hhh]h)}(hreason for connection timeout.h]hreason for connection timeout.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM#hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM#hjxubeh}(h]h ]h"]h$]h&]uh1j$hj\ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj\ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jscfg80211_roamed (C function)c.cfg80211_roamedhNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hYvoid cfg80211_roamed (struct net_device *dev, struct cfg80211_roam_info *info, gfp_t gfp)h]j)}(hXvoid cfg80211_roamed(struct net_device *dev, struct cfg80211_roam_info *info, gfp_t gfp)h](j)}(hvoidh]hvoid}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMJ#ubj)}(h h]h }(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,hhhj>hMJ#ubj)}(hcfg80211_roamedh]j)}(hcfg80211_roamedh]hcfg80211_roamed}(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjMubah}(h]h ](jjeh"]h$]h&]jjuh1jhj,hhhj>hMJ#ubj)}(hD(struct net_device *dev, struct cfg80211_roam_info *info, gfp_t gfp)h](j%)}(hstruct net_device *devh](j)}(hjh]hstruct}(hjmhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjiubj)}(h h]h }(hjzhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjiubh)}(hhh]j)}(h net_deviceh]h net_device}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jf)}j^jSsbc.cfg80211_roamedasbuh1hhjiubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjiubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjiubj)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjiubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjeubj%)}(hstruct cfg80211_roam_info *infoh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hcfg80211_roam_infoh]hcfg80211_roam_info}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jc.cfg80211_roamedasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hinfoh]hinfo}(hj6hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjeubj%)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjTmodnameN classnameNj j )}j ]jc.cfg80211_roamedasbuh1hhjKubj)}(h h]h }(hjphhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubj)}(hgfph]hgfp}(hj~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjeubeh}(h]h ]h"]h$]h&]jjuh1jhj,hhhj>hMJ#ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj(hhhj>hMJ#ubah}(h]j#ah ](jjeh"]h$]h&]jj)jhuh1j|hj>hMJ#hj%hhubj)}(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.hhMJ#hjhhubah}(h]h ]h"]h$]h&]uh1jhj%hhhj>hMJ#ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjjjjjjuh1jwhhhjcchNhNubj)}(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&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMN#hjubj%)}(hhh](j*)}(h*``struct net_device *dev`` network device h](j0)}(h``struct net_device *dev``h]j,)}(hjh]hstruct net_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhML#hjubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhML#hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhML#hjubj*)}(hh``struct cfg80211_roam_info *info`` information about the new BSS. struct :c:type:`cfg80211_roam_info`. h](j0)}(h#``struct cfg80211_roam_info *info``h]j,)}(hj" h]hstruct cfg80211_roam_info *info}(hj$ hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMM#hj ubjJ)}(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,)}(hjE h]hcfg80211_roam_info}(hjG hhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjC ubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJcfg80211_roam_infouh1hhj7 hMM#hj; ubh.}(hj; hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj7 hMM#hj8 ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj7 hMM#hjubj*)}(h``gfp_t gfp`` allocation flags h](j0)}(h ``gfp_t gfp``h]j,)}(hj~ h]h gfp_t gfp}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj| ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMN#hjx ubjJ)}(hhh]h)}(hallocation flagsh]hallocation flags}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMN#hj ubah}(h]h ]h"]h$]h&]uh1jIhjx ubeh}(h]h ]h"]h$]h&]uh1j)hj hMN#hjubeh}(h]h ]h"]h$]h&]uh1j$hjubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMP#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.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMO#hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js"cfg80211_disconnected (C function)c.cfg80211_disconnectedhNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hvoid cfg80211_disconnected (struct net_device *dev, u16 reason, const u8 *ie, size_t ie_len, bool locally_generated, gfp_t gfp)h]j)}(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}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMv#ubj)}(h h]h }(hj !hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhj !hMv#ubj)}(hcfg80211_disconnectedh]j)}(hcfg80211_disconnectedh]hcfg80211_disconnected}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj hhhj !hMv#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](j)}(hjh]hstruct}(hj;!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7!ubj)}(h h]h }(hjH!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7!ubh)}(hhh]j)}(h net_deviceh]h net_device}(hjY!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjV!ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj[!modnameN classnameNj j )}j ]jf)}j^j!!sbc.cfg80211_disconnectedasbuh1hhj7!ubj)}(h h]h }(hjy!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7!ubjz)}(hj}h]h*}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj7!ubj)}(hdevh]hdev}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7!ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj3!ubj%)}(h u16 reasonh](h)}(hhh]j)}(hu16h]hu16}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj!modnameN classnameNj j )}j ]ju!c.cfg80211_disconnectedasbuh1hhj!ubj)}(h h]h }(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubj)}(hreasonh]hreason}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj3!ubj%)}(h const u8 *ieh](j)}(hjIh]hconst}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!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&] refdomainj8reftypej^ reftargetj"modnameN classnameNj j )}j ]ju!c.cfg80211_disconnectedasbuh1hhj!ubj)}(h h]h }(hj1"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubjz)}(hj}h]h*}(hj?"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj!ubj)}(hieh]hie}(hjL"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj3!ubj%)}(h size_t ie_lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjh"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhje"ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjj"modnameN classnameNj j )}j ]ju!c.cfg80211_disconnectedasbuh1hhja"ubj)}(h h]h }(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhja"ubj)}(hie_lenh]hie_len}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhja"ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj3!ubj%)}(hbool locally_generatedh](j)}(hj5h]hbool}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"ubj)}(h h]h }(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"ubj)}(hlocally_generatedh]hlocally_generated}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj3!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&] refdomainj8reftypej^ reftargetj"modnameN classnameNj j )}j ]ju!c.cfg80211_disconnectedasbuh1hhj"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&]noemphjjuh1j$hj3!ubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhj !hMv#ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj hhhj !hMv#ubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1j|hj !hMv#hj hhubj)}(hhh]h)}(h+notify cfg80211 that connection was droppedh]h+notify cfg80211 that connection was dropped}(hj:#hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMv#hj7#hhubah}(h]h ]h"]h$]h&]uh1jhj hhhj !hMv#ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjR#jjR#jjjuh1jwhhhjcchNhNubj)}(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&]uh1jhjZ#ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMz#hjV#ubj%)}(hhh](j*)}(h*``struct net_device *dev`` network device h](j0)}(h``struct net_device *dev``h]j,)}(hj{#h]hstruct net_device *dev}(hj}#hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjy#ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMx#hju#ubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hMx#hj#ubah}(h]h ]h"]h$]h&]uh1jIhju#ubeh}(h]h ]h"]h$]h&]uh1j)hj#hMx#hjr#ubj*)}(hI``u16 reason`` reason code for the disconnection, set it to 0 if unknown h](j0)}(h``u16 reason``h]j,)}(hj#h]h u16 reason}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj#ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM{#hj#ubjJ)}(hhh]h)}(h9reason code for the disconnection, set it to 0 if unknownh]h9reason code for the disconnection, set it to 0 if unknown}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hM{#hj#ubah}(h]h ]h"]h$]h&]uh1jIhj#ubeh}(h]h ]h"]h$]h&]uh1j)hj#hM{#hjr#ubj*)}(hU``const u8 *ie`` information elements of the deauth/disassoc frame (may be ``NULL``) h](j0)}(h``const u8 *ie``h]j,)}(hj#h]h const u8 *ie}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj#ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMy#hj#ubjJ)}(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&]uh1j+hj$ubh)}(hj$hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj$hMy#hj$ubah}(h]h ]h"]h$]h&]uh1jIhj#ubeh}(h]h ]h"]h$]h&]uh1j)hj$hMy#hjr#ubj*)}(h ``size_t ie_len`` length of IEs h](j0)}(h``size_t ie_len``h]j,)}(hj8$h]h size_t ie_len}(hj:$hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6$ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMz#hj2$ubjJ)}(hhh]h)}(h length of IEsh]h length of IEs}(hjQ$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjM$hMz#hjN$ubah}(h]h ]h"]h$]h&]uh1jIhj2$ubeh}(h]h ]h"]h$]h&]uh1j)hjM$hMz#hjr#ubj*)}(h?``bool locally_generated`` disconnection was requested locally h](j0)}(h``bool locally_generated``h]j,)}(hjq$h]hbool locally_generated}(hjs$hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjo$ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM|#hjk$ubjJ)}(hhh]h)}(h#disconnection was requested locallyh]h#disconnection was requested locally}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$hM|#hj$ubah}(h]h ]h"]h$]h&]uh1jIhjk$ubeh}(h]h ]h"]h$]h&]uh1j)hj$hM|#hjr#ubj*)}(h``gfp_t gfp`` allocation flags h](j0)}(h ``gfp_t gfp``h]j,)}(hj$h]h gfp_t gfp}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj$ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM}#hj$ubjJ)}(hhh]h)}(hallocation flagsh]hallocation flags}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$hM}#hj$ubah}(h]h ]h"]h$]h&]uh1jIhj$ubeh}(h]h ]h"]h$]h&]uh1j)hj$hM}#hjr#ubeh}(h]h ]h"]h$]h&]uh1j$hjV#ubh)}(h**Description**h]j)}(hj$h]h Description}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hjV#ubh)}(hnAfter it calls this function, the driver should enter an idle state and not try to connect to any AP any more.h]hnAfter it calls this function, the driver should enter an idle state and not try to connect to any AP any more.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM~#hjV#ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js&cfg80211_ready_on_channel (C function)c.cfg80211_ready_on_channelhNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hvoid cfg80211_ready_on_channel (struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, unsigned int duration, gfp_t gfp)h]j)}(hvoid cfg80211_ready_on_channel(struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, unsigned int duration, gfp_t gfp)h](j)}(hvoidh]hvoid}(hj*%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&%hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#ubj)}(h h]h }(hj9%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&%hhhj8%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&]jjuh1jhj&%hhhj8%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](j)}(hjh]hstruct}(hjg%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjc%ubj)}(h h]h }(hjt%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjc%ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj%modnameN classnameNj j )}j ]jf)}j^jM%sbc.cfg80211_ready_on_channelasbuh1hhjc%ubj)}(h h]h }(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjc%ubjz)}(hj}h]h*}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjc%ubj)}(hwdevh]hwdev}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjc%ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj_%ubj%)}(h u64 cookieh](h)}(hhh]j)}(hu64h]hu64}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ 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&]noemphjjuh1j$hj_%ubj%)}(hstruct ieee80211_channel *chanh](j)}(hjh]hstruct}(hj!&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&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&] refdomainj8reftypej^ reftargetjA&modnameN classnameNj j )}j K]j%c.cfg80211_ready_on_channelasbuh1hhj&ubj)}(h h]h }(hj]&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubjz)}(hj}h]h*}(hjk&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj&ubj)}(hchanh]hchan}(hjx&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj_%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&]noemphjjuh1j$hj_%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&] refdomainj8reftypej^ reftargetj&modnameN classnameNj j )}j ]j%c.cfg80211_ready_on_channelasbuh1hhj&ubj)}(h h]h }(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubj)}(hgfph]hgfp}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj_%ubeh}(h]h ]h"]h$]h&]jjuh1jhj&%hhhj8%hM#ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj"%hhhj8%hM#ubah}(h]j%ah ](jjeh"]h$]h&]jj)jhuh1j|hj8%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#hj8'hhubah}(h]h ]h"]h$]h&]uh1jhj%hhhj8%hM#ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjS'jjS'jjjuh1jwhhhjcchNhNubj)}(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&]uh1jhj['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](j0)}(h``struct wireless_dev *wdev``h]j,)}(hj|'h]hstruct wireless_dev *wdev}(hj~'hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjz'ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hjv'ubjJ)}(hhh]h)}(hwireless deviceh]hwireless device}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hM#hj'ubah}(h]h ]h"]h$]h&]uh1jIhjv'ubeh}(h]h ]h"]h$]h&]uh1j)hj'hM#hjs'ubj*)}(h"``u64 cookie`` the request cookie h](j0)}(h``u64 cookie``h]j,)}(hj'h]h u64 cookie}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj'ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj'ubjJ)}(hhh]h)}(hthe request cookieh]hthe request cookie}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hM#hj'ubah}(h]h ]h"]h$]h&]uh1jIhj'ubeh}(h]h ]h"]h$]h&]uh1j)hj'hM#hjs'ubj*)}(hX``struct ieee80211_channel *chan`` The current channel (from remain_on_channel request) h](j0)}(h"``struct ieee80211_channel *chan``h]j,)}(hj'h]hstruct ieee80211_channel *chan}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj'ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj'ubjJ)}(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&]uh1jIhj'ubeh}(h]h ]h"]h$]h&]uh1j)hj(hM#hjs'ubj*)}(hd``unsigned int duration`` Duration in milliseconds that the driver intents to remain on the channel h](j0)}(h``unsigned int duration``h]j,)}(hj'(h]hunsigned int duration}(hj)(hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj%(ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj!(ubjJ)}(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&]uh1jIhj!(ubeh}(h]h ]h"]h$]h&]uh1j)hj<(hM#hjs'ubj*)}(h``gfp_t gfp`` allocation flagsh](j0)}(h ``gfp_t gfp``h]j,)}(hja(h]h gfp_t gfp}(hjc(hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj_(ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj[(ubjJ)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjz(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hjw(ubah}(h]h ]h"]h$]h&]uh1jIhj[(ubeh}(h]h ]h"]h$]h&]uh1j)hjv(hM#hjs'ubeh}(h]h ]h"]h$]h&]uh1j$hjW'ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js/cfg80211_remain_on_channel_expired (C function)$c.cfg80211_remain_on_channel_expiredhNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hzvoid cfg80211_remain_on_channel_expired (struct wireless_dev *wdev, u64 cookie, struct ieee80211_channel *chan, gfp_t gfp)h]j)}(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](j)}(hjh]hstruct}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(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&] refdomainj8reftypej^ reftargetj)modnameN classnameNj j )}j ]jf)}j^j(sb$c.cfg80211_remain_on_channel_expiredasbuh1hhj(ubj)}(h h]h }(hj6)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(ubjz)}(hj}h]h*}(hjD)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj(ubj)}(hwdevh]hwdev}(hjQ)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj(ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj(ubj%)}(h u64 cookieh](h)}(hhh]j)}(hu64h]hu64}(hjm)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjj)ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjo)modnameN classnameNj j )}j ]j2)$c.cfg80211_remain_on_channel_expiredasbuh1hhjf)ubj)}(h h]h }(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjf)ubj)}(hcookieh]hcookie}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjf)ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj(ubj%)}(hstruct ieee80211_channel *chanh](j)}(hjh]hstruct}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)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&] refdomainj8reftypej^ reftargetj)modnameN classnameNj j )}j ]j2)$c.cfg80211_remain_on_channel_expiredasbuh1hhj)ubj)}(h h]h }(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubjz)}(hj}h]h*}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj)ubj)}(hchanh]hchan}(hj *hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj(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&] refdomainj8reftypej^ reftargetj'*modnameN classnameNj j )}j ]j2)$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&]noemphjjuh1j$hj(ubeh}(h]h ]h"]h$]h&]jjuh1jhj(hhhj(hM#ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj(hhhj(hM#ubah}(h]j(ah ](jjeh"]h$]h&]jj)jhuh1j|hj(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#hjx*hhubah}(h]h ]h"]h$]h&]uh1jhj(hhhj(hM#ubeh}(h]h ](j8functioneh"]h$]h&]jj8jj*jj*jjjuh1jwhhhjcchNhNubj)}(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&]uh1jhj*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](j0)}(h``struct wireless_dev *wdev``h]j,)}(hj*h]hstruct wireless_dev *wdev}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj*ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj*ubjJ)}(hhh]h)}(hwireless deviceh]hwireless device}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hM#hj*ubah}(h]h ]h"]h$]h&]uh1jIhj*ubeh}(h]h ]h"]h$]h&]uh1j)hj*hM#hj*ubj*)}(h"``u64 cookie`` the request cookie h](j0)}(h``u64 cookie``h]j,)}(hj*h]h u64 cookie}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj*ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj*ubjJ)}(hhh]h)}(hthe request cookieh]hthe request cookie}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj +hM#hj +ubah}(h]h ]h"]h$]h&]uh1jIhj*ubeh}(h]h ]h"]h$]h&]uh1j)hj +hM#hj*ubj*)}(hX``struct ieee80211_channel *chan`` The current channel (from remain_on_channel request) h](j0)}(h"``struct ieee80211_channel *chan``h]j,)}(hj.+h]hstruct ieee80211_channel *chan}(hj0+hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj,+ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj(+ubjJ)}(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&]uh1jIhj(+ubeh}(h]h ]h"]h$]h&]uh1j)hjC+hM#hj*ubj*)}(h``gfp_t gfp`` allocation flagsh](j0)}(h ``gfp_t gfp``h]j,)}(hjg+h]h gfp_t gfp}(hji+hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hje+ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hja+ubjJ)}(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&]uh1jIhja+ubeh}(h]h ]h"]h$]h&]uh1j)hj|+hM#hj*ubeh}(h]h ]h"]h$]h&]uh1j$hj*ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jscfg80211_new_sta (C function)c.cfg80211_new_stahNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hlvoid cfg80211_new_sta (struct wireless_dev *wdev, const u8 *mac_addr, struct station_info *sinfo, gfp_t gfp)h]j)}(hkvoid cfg80211_new_sta(struct wireless_dev *wdev, const u8 *mac_addr, struct station_info *sinfo, gfp_t gfp)h](j)}(hvoidh]hvoid}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#ubj)}(h h]h }(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+hhhj+hM#ubj)}(hcfg80211_new_stah]j)}(hcfg80211_new_stah]hcfg80211_new_sta}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj+hhhj+hM#ubj)}(hV(struct wireless_dev *wdev, const u8 *mac_addr, struct station_info *sinfo, gfp_t gfp)h](j%)}(hstruct wireless_dev *wdevh](j)}(hjh]hstruct}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+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&] refdomainj8reftypej^ reftargetj,modnameN classnameNj j )}j ]jf)}j^j+sbc.cfg80211_new_staasbuh1hhj+ubj)}(h h]h }(hj<,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+ubjz)}(hj}h]h*}(hjJ,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj+ubj)}(hwdevh]hwdev}(hjW,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj+ubj%)}(hconst u8 *mac_addrh](j)}(hjIh]hconst}(hjp,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjl,ubj)}(h h]h }(hj},hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjl,ubh)}(hhh]j)}(hu8h]hu8}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj,modnameN classnameNj j )}j ]j8,c.cfg80211_new_staasbuh1hhjl,ubj)}(h h]h }(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjl,ubjz)}(hj}h]h*}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjl,ubj)}(hmac_addrh]hmac_addr}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjl,ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj+ubj%)}(hstruct station_info *sinfoh](j)}(hjh]hstruct}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,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&] refdomainj8reftypej^ reftargetj-modnameN classnameNj j )}j ]j8,c.cfg80211_new_staasbuh1hhj,ubj)}(h h]h }(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubjz)}(hj}h]h*}(hj*-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj,ubj)}(hsinfoh]hsinfo}(hj7-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj+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&] refdomainj8reftypej^ reftargetjU-modnameN classnameNj j )}j ]j8,c.cfg80211_new_staasbuh1hhjL-ubj)}(h h]h }(hjq-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjL-ubj)}(hgfph]hgfp}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjL-ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj+ubeh}(h]h ]h"]h$]h&]jjuh1jhj+hhhj+hM#ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj+hhhj+hM#ubah}(h]j+ah ](jjeh"]h$]h&]jj)jhuh1j|hj+hM#hj+hhubj)}(hhh]h)}(hnotify userspace about stationh]hnotify userspace about station}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj-hhubah}(h]h ]h"]h$]h&]uh1jhj+hhhj+hM#ubeh}(h]h ](j8functioneh"]h$]h&]jj8jj-jj-jjjuh1jwhhhjcchNhNubj)}(h**Parameters** ``struct wireless_dev *wdev`` the wireless device ``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&]uh1jhj-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*)}(h2``struct wireless_dev *wdev`` the wireless device h](j0)}(h``struct wireless_dev *wdev``h]j,)}(hj-h]hstruct wireless_dev *wdev}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj-ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj-ubjJ)}(hhh]h)}(hthe wireless deviceh]hthe wireless device}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-hM#hj.ubah}(h]h ]h"]h$]h&]uh1jIhj-ubeh}(h]h ]h"]h$]h&]uh1j)hj-hM#hj-ubj*)}(h-``const u8 *mac_addr`` the station's address h](j0)}(h``const u8 *mac_addr``h]j,)}(hj#.h]hconst u8 *mac_addr}(hj%.hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj!.ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj.ubjJ)}(hhh]h)}(hthe station's addressh]hthe station’s address}(hj<.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8.hM#hj9.ubah}(h]h ]h"]h$]h&]uh1jIhj.ubeh}(h]h ]h"]h$]h&]uh1j)hj8.hM#hj-ubj*)}(h7``struct station_info *sinfo`` the station information h](j0)}(h``struct station_info *sinfo``h]j,)}(hj\.h]hstruct station_info *sinfo}(hj^.hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjZ.ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hjV.ubjJ)}(hhh]h)}(hthe station informationh]hthe station information}(hju.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjq.hM#hjr.ubah}(h]h ]h"]h$]h&]uh1jIhjV.ubeh}(h]h ]h"]h$]h&]uh1j)hjq.hM#hj-ubj*)}(h``gfp_t gfp`` allocation flagsh](j0)}(h ``gfp_t gfp``h]j,)}(hj.h]h gfp_t gfp}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj.ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM#hj.ubjJ)}(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&]uh1jIhj.ubeh}(h]h ]h"]h$]h&]uh1j)hj.hM#hj-ubeh}(h]h ]h"]h$]h&]uh1j$hj-ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jscfg80211_rx_mgmt (C function)c.cfg80211_rx_mgmthNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hnbool cfg80211_rx_mgmt (struct wireless_dev *wdev, int freq, int sig_dbm, const u8 *buf, size_t len, u32 flags)h]j)}(hmbool cfg80211_rx_mgmt(struct wireless_dev *wdev, int freq, int sig_dbm, const u8 *buf, size_t len, u32 flags)h](j)}(hj5h]hbool}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMQ$ubj)}(h h]h }(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.hhhj.hMQ$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.hMQ$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](j)}(hjh]hstruct}(hj+/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'/ubj)}(h h]h }(hj8/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'/ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hjI/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjF/ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjK/modnameN classnameNj j )}j ]jf)}j^j/sbc.cfg80211_rx_mgmtasbuh1hhj'/ubj)}(h h]h }(hji/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'/ubjz)}(hj}h]h*}(hjw/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj'/ubj)}(hwdevh]hwdev}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'/ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj#/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&]noemphjjuh1j$hj#/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&]noemphjjuh1j$hj#/ubj%)}(h const u8 *bufh](j)}(hjIh]hconst}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubj)}(h h]h }(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubh)}(hhh]j)}(hu8h]hu8}(hj%0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"0ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj'0modnameN classnameNj j )}j ]je/c.cfg80211_rx_mgmtasbuh1hhj0ubj)}(h h]h }(hjC0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubjz)}(hj}h]h*}(hjQ0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj0ubj)}(hbufh]hbuf}(hj^0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj#/ubj%)}(h size_t lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hjz0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjw0ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj|0modnameN classnameNj j )}j ]je/c.cfg80211_rx_mgmtasbuh1hhjs0ubj)}(h h]h }(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjs0ubj)}(hlenh]hlen}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjs0ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj#/ubj%)}(h u32 flagsh](h)}(hhh]j)}(hu32h]hu32}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj0modnameN classnameNj j )}j ]je/c.cfg80211_rx_mgmtasbuh1hhj0ubj)}(h h]h }(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubj)}(hflagsh]hflags}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj#/ubeh}(h]h ]h"]h$]h&]jjuh1jhj.hhhj.hMQ$ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj.hhhj.hMQ$ubah}(h]j.ah ](jjeh"]h$]h&]jj)jhuh1j|hj.hMQ$hj.hhubj)}(hhh]h)}(h6notification of received, unprocessed management frameh]h6notification of received, unprocessed management frame}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMQ$hj1hhubah}(h]h ]h"]h$]h&]uh1jhj.hhhj.hMQ$ubeh}(h]h ](j8functioneh"]h$]h&]jj8jj01jj01jjjuh1jwhhhjcchNhNubj)}(hX **Parameters** ``struct wireless_dev *wdev`` wireless device receiving the frame ``int freq`` Frequency on which the frame was received in MHz ``int sig_dbm`` signal strength in dBm, or 0 if unknown ``const u8 *buf`` Management frame (header + body) ``size_t len`` length of the frame data ``u32 flags`` flags, as defined in enum nl80211_rxmgmt_flags **Description** This function is called whenever an Action frame is received for a station mode interface, but is not processed in kernel. **Return** ``true`` if a user space application has registered for this frame. For action frames, that makes it responsible for rejecting unrecognized action frames; ``false`` otherwise, in which case for action frames the driver is responsible for rejecting the frame.h](h)}(h**Parameters**h]j)}(hj:1h]h Parameters}(hj<1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj81ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMU$hj41ubj%)}(hhh](j*)}(hB``struct wireless_dev *wdev`` wireless device receiving the frame h](j0)}(h``struct wireless_dev *wdev``h]j,)}(hjY1h]hstruct wireless_dev *wdev}(hj[1hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjW1ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMR$hjS1ubjJ)}(hhh]h)}(h#wireless device receiving the frameh]h#wireless device receiving the frame}(hjr1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjn1hMR$hjo1ubah}(h]h ]h"]h$]h&]uh1jIhjS1ubeh}(h]h ]h"]h$]h&]uh1j)hjn1hMR$hjP1ubj*)}(h>``int freq`` Frequency on which the frame was received in MHz h](j0)}(h ``int freq``h]j,)}(hj1h]hint freq}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj1ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMS$hj1ubjJ)}(hhh]h)}(h0Frequency on which the frame was received in MHzh]h0Frequency on which the frame was received in MHz}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1hMS$hj1ubah}(h]h ]h"]h$]h&]uh1jIhj1ubeh}(h]h ]h"]h$]h&]uh1j)hj1hMS$hjP1ubj*)}(h8``int sig_dbm`` signal strength in dBm, or 0 if unknown h](j0)}(h``int sig_dbm``h]j,)}(hj1h]h int sig_dbm}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj1ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMT$hj1ubjJ)}(hhh]h)}(h'signal strength in dBm, or 0 if unknownh]h'signal strength in dBm, or 0 if unknown}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1hMT$hj1ubah}(h]h ]h"]h$]h&]uh1jIhj1ubeh}(h]h ]h"]h$]h&]uh1j)hj1hMT$hjP1ubj*)}(h3``const u8 *buf`` Management frame (header + body) h](j0)}(h``const u8 *buf``h]j,)}(hj2h]h const u8 *buf}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj2ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMU$hj1ubjJ)}(hhh]h)}(h Management frame (header + body)h]h Management frame (header + body)}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hMU$hj2ubah}(h]h ]h"]h$]h&]uh1jIhj1ubeh}(h]h ]h"]h$]h&]uh1j)hj2hMU$hjP1ubj*)}(h(``size_t len`` length of the frame data h](j0)}(h``size_t len``h]j,)}(hj=2h]h size_t len}(hj?2hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj;2ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMV$hj72ubjJ)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hjV2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjR2hMV$hjS2ubah}(h]h ]h"]h$]h&]uh1jIhj72ubeh}(h]h ]h"]h$]h&]uh1j)hjR2hMV$hjP1ubj*)}(h=``u32 flags`` flags, as defined in enum nl80211_rxmgmt_flags h](j0)}(h ``u32 flags``h]j,)}(hjv2h]h u32 flags}(hjx2hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjt2ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMW$hjp2ubjJ)}(hhh]h)}(h.flags, as defined in enum nl80211_rxmgmt_flagsh]h.flags, as defined in enum nl80211_rxmgmt_flags}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hMW$hj2ubah}(h]h ]h"]h$]h&]uh1jIhjp2ubeh}(h]h ]h"]h$]h&]uh1j)hj2hMW$hjP1ubeh}(h]h ]h"]h$]h&]uh1j$hj41ubh)}(h**Description**h]j)}(hj2h]h Description}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMY$hj41ubh)}(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.}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhMX$hj41ubh)}(h **Return**h]j)}(hj2h]hReturn}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM[$hj41ubh)}(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}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj2ubh if a user space application has registered for this frame. For action frames, that makes it responsible for rejecting unrecognized action frames; }(hj2hhhNhNubj,)}(h ``false``h]hfalse}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj2ubh^ otherwise, in which case for action frames the driver is responsible for rejecting the frame.}(hj2hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM\$hj41ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js$cfg80211_mgmt_tx_status (C function)c.cfg80211_mgmt_tx_statushNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(htvoid cfg80211_mgmt_tx_status (struct wireless_dev *wdev, u64 cookie, const u8 *buf, size_t len, bool ack, gfp_t gfp)h]j)}(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=3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj93hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$ubj)}(h h]h }(hjL3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj93hhhjK3hM$ubj)}(hcfg80211_mgmt_tx_statush]j)}(hcfg80211_mgmt_tx_statush]hcfg80211_mgmt_tx_status}(hj^3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZ3ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj93hhhjK3hM$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](j)}(hjh]hstruct}(hjz3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjv3ubj)}(h h]h }(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjv3ubh)}(hhh]j)}(h wireless_devh]h wireless_dev}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj3modnameN classnameNj j )}j ]jf)}j^j`3sbc.cfg80211_mgmt_tx_statusasbuh1hhjv3ubj)}(h h]h }(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjv3ubjz)}(hj}h]h*}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjv3ubj)}(hwdevh]hwdev}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjv3ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjr3ubj%)}(h u64 cookieh](h)}(hhh]j)}(hu64h]hu64}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj3modnameN classnameNj j )}j ]j3c.cfg80211_mgmt_tx_statusasbuh1hhj3ubj)}(h h]h }(hj 4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3ubj)}(hcookieh]hcookie}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjr3ubj%)}(h const u8 *bufh](j)}(hjIh]hconst}(hj44hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj04ubj)}(h h]h }(hjA4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj04ubh)}(hhh]j)}(hu8h]hu8}(hjR4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjO4ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjT4modnameN classnameNj j )}j ]j3c.cfg80211_mgmt_tx_statusasbuh1hhj04ubj)}(h h]h }(hjp4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj04ubjz)}(hj}h]h*}(hj~4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj04ubj)}(hbufh]hbuf}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj04ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjr3ubj%)}(h size_t lenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj4modnameN classnameNj j )}j ]j3c.cfg80211_mgmt_tx_statusasbuh1hhj4ubj)}(h h]h }(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubj)}(hlenh]hlen}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjr3ubj%)}(hbool ackh](j)}(hj5h]hbool}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubj)}(h h]h }(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubj)}(hackh]hack}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjr3ubj%)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj#5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj 5ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj%5modnameN classnameNj j )}j ]j3c.cfg80211_mgmt_tx_statusasbuh1hhj5ubj)}(h h]h }(hjA5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubj)}(hgfph]hgfp}(hjO5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjr3ubeh}(h]h ]h"]h$]h&]jjuh1jhj93hhhjK3hM$ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj53hhhjK3hM$ubah}(h]j03ah ](jjeh"]h$]h&]jj)jhuh1j|hjK3hM$hj23hhubj)}(hhh]h)}(h.notification of TX status for management frameh]h.notification of TX status for management frame}(hjy5hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hjv5hhubah}(h]h ]h"]h$]h&]uh1jhj23hhhjK3hM$ubeh}(h]h ](j8functioneh"]h$]h&]jj8jj5jj5jjjuh1jwhhhjcchNhNubj)}(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)}(hj5h]h Parameters}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj5ubj%)}(hhh](j*)}(hB``struct wireless_dev *wdev`` wireless device receiving the frame h](j0)}(h``struct wireless_dev *wdev``h]j,)}(hj5h]hstruct wireless_dev *wdev}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj5ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj5ubjJ)}(hhh]h)}(h#wireless device receiving the frameh]h#wireless device receiving the frame}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hM$hj5ubah}(h]h ]h"]h$]h&]uh1jIhj5ubeh}(h]h ]h"]h$]h&]uh1j)hj5hM$hj5ubj*)}(h:``u64 cookie`` Cookie returned by cfg80211_ops::mgmt_tx() h](j0)}(h``u64 cookie``h]j,)}(hj5h]h u64 cookie}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj5ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj5ubjJ)}(hhh]h)}(h*Cookie returned by cfg80211_ops::mgmt_tx()h]h*Cookie returned by cfg80211_ops::mgmt_tx()}(hj 6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM$hj 6ubah}(h]h ]h"]h$]h&]uh1jIhj5ubeh}(h]h ]h"]h$]h&]uh1j)hj6hM$hj5ubj*)}(h3``const u8 *buf`` Management frame (header + body) h](j0)}(h``const u8 *buf``h]j,)}(hj,6h]h const u8 *buf}(hj.6hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj*6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj&6ubjJ)}(hhh]h)}(h Management frame (header + body)h]h Management frame (header + body)}(hjE6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjA6hM$hjB6ubah}(h]h ]h"]h$]h&]uh1jIhj&6ubeh}(h]h ]h"]h$]h&]uh1j)hjA6hM$hj5ubj*)}(h(``size_t len`` length of the frame data h](j0)}(h``size_t len``h]j,)}(hje6h]h size_t len}(hjg6hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjc6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj_6ubjJ)}(hhh]h)}(hlength of the frame datah]hlength of the frame data}(hj~6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjz6hM$hj{6ubah}(h]h ]h"]h$]h&]uh1jIhj_6ubeh}(h]h ]h"]h$]h&]uh1j)hjz6hM$hj5ubj*)}(h,``bool ack`` Whether frame was acknowledged h](j0)}(h ``bool ack``h]j,)}(hj6h]hbool ack}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj6ubjJ)}(hhh]h)}(hWhether frame was acknowledgedh]hWhether frame was acknowledged}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM$hj6ubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j)hj6hM$hj5ubj*)}(h``gfp_t gfp`` context flags h](j0)}(h ``gfp_t gfp``h]j,)}(hj6h]h gfp_t gfp}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj6ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj6ubjJ)}(hhh]h)}(h context flagsh]h context flags}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM$hj6ubah}(h]h ]h"]h$]h&]uh1jIhj6ubeh}(h]h ]h"]h$]h&]uh1j)hj6hM$hj5ubeh}(h]h ]h"]h$]h&]uh1j$hj5ubh)}(h**Description**h]j)}(hj7h]h Description}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj5ubh)}(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.}(hj(7hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj5ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js%cfg80211_cqm_rssi_notify (C function)c.cfg80211_cqm_rssi_notifyhNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(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)}(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}(hjW7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjS7hhh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$ubj)}(h h]h }(hjf7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjS7hhhje7hM$ubj)}(hcfg80211_cqm_rssi_notifyh]j)}(hcfg80211_cqm_rssi_notifyh]hcfg80211_cqm_rssi_notify}(hjx7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjt7ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjS7hhhje7hM$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](j)}(hjh]hstruct}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubj)}(h h]h }(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubh)}(hhh]j)}(h net_deviceh]h net_device}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj7modnameN classnameNj j )}j ]jf)}j^jz7sbc.cfg80211_cqm_rssi_notifyasbuh1hhj7ubj)}(h h]h }(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubjz)}(hj}h]h*}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj7ubj)}(hdevh]hdev}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj7ubj%)}(h0enum nl80211_cqm_rssi_threshold_event rssi_eventh](j)}(hjh]henum}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubj)}(h h]h }(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubh)}(hhh]j)}(h nl80211_cqm_rssi_threshold_eventh]h nl80211_cqm_rssi_threshold_event}(hj$8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!8ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj&8modnameN classnameNj j )}j ]j7c.cfg80211_cqm_rssi_notifyasbuh1hhj8ubj)}(h h]h }(hjB8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubj)}(h rssi_eventh]h rssi_event}(hjP8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj7ubj%)}(hs32 rssi_levelh](h)}(hhh]j)}(hs32h]hs32}(hjl8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhji8ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjn8modnameN classnameNj j )}j ]j7c.cfg80211_cqm_rssi_notifyasbuh1hhje8ubj)}(h h]h }(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhje8ubj)}(h rssi_levelh]h rssi_level}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhje8ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj7ubj%)}(h gfp_t gfph](h)}(hhh]j)}(hgfp_th]hgfp_t}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj8modnameN classnameNj j )}j ]j7c.cfg80211_cqm_rssi_notifyasbuh1hhj8ubj)}(h h]h }(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubj)}(hgfph]hgfp}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj7ubeh}(h]h ]h"]h$]h&]jjuh1jhjS7hhhje7hM$ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjO7hhhje7hM$ubah}(h]jJ7ah ](jjeh"]h$]h&]jj)jhuh1j|hje7hM$hjL7hhubj)}(hhh]h)}(h(connection quality monitoring rssi eventh]h(connection quality monitoring rssi event}(hj 9hhhNhNubah}(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&]uh1jhjL7hhhje7hM$ubeh}(h]h ](j8functioneh"]h$]h&]jj8jj"9jj"9jjjuh1jwhhhjcchNhNubj)}(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)}(hj,9h]h Parameters}(hj.9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*9ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj&9ubj%)}(hhh](j*)}(h*``struct net_device *dev`` network device h](j0)}(h``struct net_device *dev``h]j,)}(hjK9h]hstruct net_device *dev}(hjM9hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjI9ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hjE9ubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hjd9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`9hM$hja9ubah}(h]h ]h"]h$]h&]uh1jIhjE9ubeh}(h]h ]h"]h$]h&]uh1j)hj`9hM$hjB9ubj*)}(hN``enum nl80211_cqm_rssi_threshold_event rssi_event`` the triggered RSSI event h](j0)}(h4``enum nl80211_cqm_rssi_threshold_event rssi_event``h]j,)}(hj9h]h0enum nl80211_cqm_rssi_threshold_event rssi_event}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj9ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj~9ubjJ)}(hhh]h)}(hthe triggered RSSI eventh]hthe triggered RSSI event}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hM$hj9ubah}(h]h ]h"]h$]h&]uh1jIhj~9ubeh}(h]h ]h"]h$]h&]uh1j)hj9hM$hjB9ubj*)}(h>``s32 rssi_level`` new RSSI level value or 0 if not available h](j0)}(h``s32 rssi_level``h]j,)}(hj9h]hs32 rssi_level}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj9ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj9ubjJ)}(hhh]h)}(h*new RSSI level value or 0 if not availableh]h*new RSSI level value or 0 if not available}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hM$hj9ubah}(h]h ]h"]h$]h&]uh1jIhj9ubeh}(h]h ]h"]h$]h&]uh1j)hj9hM$hjB9ubj*)}(h``gfp_t gfp`` context flags h](j0)}(h ``gfp_t gfp``h]j,)}(hj9h]h gfp_t gfp}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj9ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj9ubjJ)}(hhh]h)}(h context flagsh]h context flags}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj :hM$hj :ubah}(h]h ]h"]h$]h&]uh1jIhj9ubeh}(h]h ]h"]h$]h&]uh1j)hj :hM$hjB9ubeh}(h]h ]h"]h$]h&]uh1j$hj&9ubh)}(h**Description**h]j)}(hj1:h]h Description}(hj3:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/:ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj&9ubh)}(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.}(hjG:hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj&9ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js(cfg80211_cqm_pktloss_notify (C function)c.cfg80211_cqm_pktloss_notifyhNtauh1jfhjcchhhNhNubjx)}(hhh](j})}(hevoid cfg80211_cqm_pktloss_notify (struct net_device *dev, const u8 *peer, u32 num_packets, gfp_t gfp)h]j)}(hdvoid cfg80211_cqm_pktloss_notify(struct net_device *dev, const u8 *peer, u32 num_packets, gfp_t gfp)h](j)}(hvoidh]hvoid}(hjv:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjr: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&]uh1jhjr:hhhj:hM$ubj)}(hcfg80211_cqm_pktloss_notifyh]j)}(hcfg80211_cqm_pktloss_notifyh]hcfg80211_cqm_pktloss_notify}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjr:hhhj:hM$ubj)}(hD(struct net_device *dev, const u8 *peer, u32 num_packets, gfp_t gfp)h](j%)}(hstruct net_device *devh](j)}(hjh]hstruct}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:ubj)}(h h]h }(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:ubh)}(hhh]j)}(h net_deviceh]h net_device}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj:modnameN classnameNj j )}j ]jf)}j^j:sbc.cfg80211_cqm_pktloss_notifyasbuh1hhj:ubj)}(h h]h }(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:ubjz)}(hj}h]h*}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj:ubj)}(hdevh]hdev}(hj ;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj:ubj%)}(hconst u8 *peerh](j)}(hjIh]hconst}(hj%;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!;ubj)}(h h]h }(hj2;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!;ubh)}(hhh]j)}(hu8h]hu8}(hjC;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@;ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjE;modnameN classnameNj j )}j ]j:c.cfg80211_cqm_pktloss_notifyasbuh1hhj!;ubj)}(h h]h }(hja;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!;ubjz)}(hj}h]h*}(hjo;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj!;ubj)}(hpeerh]hpeer}(hj|;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!;ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj:ubj%)}(hu32 num_packetsh](h)}(hhh]j)}(hu32h]hu32}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj;modnameN classnameNj j )}j ]j:c.cfg80211_cqm_pktloss_notifyasbuh1hhj;ubj)}(h h]h }(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj;ubj)}(h num_packetsh]h num_packets}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj;ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj: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&] refdomainj8reftypej^ reftargetj;modnameN classnameNj j )}j ]j:c.cfg80211_cqm_pktloss_notifyasbuh1hhj;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&]noemphjjuh1j$hj:ubeh}(h]h ]h"]h$]h&]jjuh1jhjr:hhhj:hM$ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjn:hhhj:hM$ubah}(h]ji:ah ](jjeh"]h$]h&]jj)jhuh1j|hj:hM$hjk:hhubj)}(hhh]h)}(h)notify userspace about packetloss to peerh]h)notify userspace about packetloss to peer}(hj6<hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj3<hhubah}(h]h ]h"]h$]h&]uh1jhjk:hhhj:hM$ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjN<jjN<jjjuh1jwhhhjcchNhNubj)}(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)}(hjX<h]h Parameters}(hjZ<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjV<ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hjR<ubj%)}(hhh](j*)}(h*``struct net_device *dev`` network device h](j0)}(h``struct net_device *dev``h]j,)}(hjw<h]hstruct net_device *dev}(hjy<hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hju<ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hjq<ubjJ)}(hhh]h)}(hnetwork deviceh]hnetwork device}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hM$hj<ubah}(h]h ]h"]h$]h&]uh1jIhjq<ubeh}(h]h ]h"]h$]h&]uh1j)hj<hM$hjn<ubj*)}(h&``const u8 *peer`` peer's MAC address h](j0)}(h``const u8 *peer``h]j,)}(hj<h]hconst u8 *peer}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj<ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj<ubjJ)}(hhh]h)}(hpeer's MAC addressh]hpeer’s MAC address}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hM$hj<ubah}(h]h ]h"]h$]h&]uh1jIhj<ubeh}(h]h ]h"]h$]h&]uh1j)hj<hM$hjn<ubj*)}(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](j0)}(h``u32 num_packets``h]j,)}(hj<h]hu32 num_packets}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj<ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj<ubjJ)}(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=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&]uh1jIhj<ubeh}(h]h ]h"]h$]h&]uh1j)hj<hM$hjn<ubj*)}(h``gfp_t gfp`` context flagsh](j0)}(h ``gfp_t gfp``h]j,)}(hj#=h]h gfp_t gfp}(hj%=hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj!=ubah}(h]h ]h"]h$]h&]uh1j/h`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj=ubjJ)}(hhh]h)}(h context flagsh]h context flags}(hj<=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:48: ./include/net/cfg80211.hhM$hj9=ubah}(h]h ]h"]h$]h&]uh1jIhj=ubeh}(h]h ]h"]h$]h&]uh1j)hj8=hM$hjn<ubeh}(h]h ]h"]h$]h&]uh1j$hjR<ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjcchhhNhNubeh}(h]actions-and-configurationah ]h"]actions and configurationah$]h&]uh1hhhhhhhhK+ubh)}(hhh](h)}(hScanning and BSS list handlingh]hScanning and BSS list handling}(hjo=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjl=hhhhhKaubh)}(hX\The scanning process itself is fairly simple, but cfg80211 offers quite a bit of helper functionality. To start a scan, the scan operation will be invoked with a scan definition. This scan definition contains the channels to scan, and the SSIDs to send probe requests for (including the wildcard, if desired). A passive scan is indicated by having no SSIDs to probe. Additionally, a scan request may contain extra information elements that should be added to the probe request. The IEs are guaranteed to be well-formed, and will not exceed the maximum length the driver advertised in the wiphy structure.h]hX\The scanning process itself is fairly simple, but cfg80211 offers quite a bit of helper functionality. To start a scan, the scan operation will be invoked with a scan definition. This scan definition contains the channels to scan, and the SSIDs to send probe requests for (including the wildcard, if desired). A passive scan is indicated by having no SSIDs to probe. Additionally, a scan request may contain extra information elements that should be added to the probe request. The IEs are guaranteed to be well-formed, and will not exceed the maximum length the driver advertised in the wiphy structure.}(hj}=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:99: ./include/net/cfg80211.hhM hjl=hhubh)}(hWhen scanning finds a BSS, cfg80211 needs to be notified of that, because it is responsible for maintaining the BSS list; the driver should not maintain a list itself. For this notification, various functions exist.h]hWhen scanning finds a BSS, cfg80211 needs to be notified of that, because it is responsible for maintaining the BSS list; the driver should not maintain a list itself. For this notification, various functions exist.}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:99: ./include/net/cfg80211.hhM hjl=hhubh)}(hSince drivers do not maintain a BSS list, there are also a number of functions to search for a BSS and obtain information about it from the BSS structure cfg80211 maintains. The BSS list is also made available to userspace.h]hSince drivers do not maintain a BSS list, there are also a number of functions to search for a BSS and obtain information about it from the BSS structure cfg80211 maintains. The BSS list is also made available to userspace.}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:99: ./include/net/cfg80211.hhM hjl=hhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jscfg80211_ssid (C struct)c.cfg80211_ssidhNtauh1jfhjl=hhhNhNubjx)}(hhh](j})}(h cfg80211_ssidh]j)}(hstruct cfg80211_ssidh](j)}(hjh]hstruct}(hj=hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhKubj)}(h h]h }(hj=hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=hhhj=hKubj)}(h cfg80211_ssidh]j)}(hj=h]h cfg80211_ssid}(hj=hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj=hhhj=hKubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj=hhhj=hKubah}(h]j=ah ](jjeh"]h$]h&]jj)jhuh1j|hj=hKhj=hhubj)}(hhh]h)}(hSSID descriptionh]hSSID description}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj>hhubah}(h]h ]h"]h$]h&]uh1jhj=hhhj=hKubeh}(h]h ](j8structeh"]h$]h&]jj8jj>jj>jjjuh1jwhhhjl=hNhNubj)}(h**Definition**:: struct cfg80211_ssid { u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; }; **Members** ``ssid`` the SSID ``ssid_len`` length of the ssidh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj)>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%>ubh:}(hj%>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj!>ubj: )}(hOstruct cfg80211_ssid { u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; };h]hOstruct cfg80211_ssid { u8 ssid[IEEE80211_MAX_SSID_LEN]; u8 ssid_len; };}hjB>sbah}(h]h ]h"]h$]h&]jjuh1j9 ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj!>ubh)}(h **Members**h]j)}(hjS>h]hMembers}(hjU>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQ>ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj!>ubj%)}(hhh](j*)}(h``ssid`` the SSID h](j0)}(h``ssid``h]j,)}(hjr>h]hssid}(hjt>hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjp>ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjl>ubjJ)}(hhh]h)}(hthe SSIDh]hthe SSID}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hM hj>ubah}(h]h ]h"]h$]h&]uh1jIhjl>ubeh}(h]h ]h"]h$]h&]uh1j)hj>hM hji>ubj*)}(h``ssid_len`` length of the ssidh](j0)}(h ``ssid_len``h]j,)}(hj>h]hssid_len}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj>ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj>ubjJ)}(hhh]h)}(hlength of the ssidh]hlength of the ssid}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj>ubah}(h]h ]h"]h$]h&]uh1jIhj>ubeh}(h]h ]h"]h$]h&]uh1j)hj>hM hji>ubeh}(h]h ]h"]h$]h&]uh1j$hj!>ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjl=hhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js cfg80211_scan_request (C struct)c.cfg80211_scan_requesthNtauh1jfhjl=hhhNhNubjx)}(hhh](j})}(hcfg80211_scan_requesth]j)}(hstruct cfg80211_scan_requesth](j)}(hjh]hstruct}(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM ubj)}(h h]h }(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?hhhj?hM ubj)}(hcfg80211_scan_requesth]j)}(hj>h]hcfg80211_scan_request}(hj%?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!?ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj?hhhj?hM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj>hhhj?hM ubah}(h]j>ah ](jjeh"]h$]h&]jj)jhuh1j|hj?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.hhM- hjD?hhubah}(h]h ]h"]h$]h&]uh1jhj>hhhj?hM ubeh}(h]h ](j8structeh"]h$]h&]jj8jj_?jj_?jjjuh1jwhhhjl=hNhNubj)}(hXk **Definition**:: struct cfg80211_scan_request { struct cfg80211_ssid *ssids; int n_ssids; u32 n_channels; const u8 *ie; size_t ie_len; u16 duration; bool duration_mandatory; u32 flags; u32 rates[NUM_NL80211_BANDS]; struct wireless_dev *wdev; u8 mac_addr[ETH_ALEN]; u8 mac_addr_mask[ETH_ALEN]; u8 bssid[ETH_ALEN]; struct wiphy *wiphy; unsigned long scan_start; bool no_cck; bool scan_6ghz; bool first_part; u32 n_6ghz_params; struct cfg80211_scan_6ghz_params *scan_6ghz_params; s8 tsf_report_link_id; struct ieee80211_channel *channels[]; }; **Members** ``ssids`` SSIDs to scan for (active scan only) ``n_ssids`` number of SSIDs ``n_channels`` total number of channels to scan ``ie`` optional information element(s) to add into Probe Request or ``NULL`` ``ie_len`` length of ie in octets ``duration`` how long to listen on each channel, in TUs. If ``duration_mandatory`` is not set, this is the maximum dwell time and the actual dwell time may be shorter. ``duration_mandatory`` if set, the scan duration must be as specified by the ``duration`` field. ``flags`` control flags from :c:type:`enum nl80211_scan_flags ` ``rates`` bitmap of rates to advertise for each band ``wdev`` the wireless device to scan for ``mac_addr`` MAC address used with randomisation ``mac_addr_mask`` MAC address mask used with randomisation, bits that are 0 in the mask should be randomised, bits that are 1 should be taken from the **mac_addr** ``bssid`` BSSID to scan for (most commonly, the wildcard BSSID) ``wiphy`` the wiphy this was for ``scan_start`` time (in jiffies) when the scan started ``no_cck`` used to send probe requests at non CCK rate in 2GHz band ``scan_6ghz`` relevant for split scan request only, true if this is a 6 GHz scan request ``first_part`` ``true`` if this is the first part of a split scan request or a scan that was not split. May be ``true`` for a **scan_6ghz** scan if no other channels were requested ``n_6ghz_params`` number of 6 GHz params ``scan_6ghz_params`` 6 GHz params ``tsf_report_link_id`` for MLO, indicates the link ID of the BSS that should be used for TSF reporting. Can be set to -1 to indicate no preference. ``channels`` channels to scan on.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjk?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjg?ubh:}(hjg?hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM1 hjc?ubj: )}(hXcstruct cfg80211_scan_request { struct cfg80211_ssid *ssids; int n_ssids; u32 n_channels; const u8 *ie; size_t ie_len; u16 duration; bool duration_mandatory; u32 flags; u32 rates[NUM_NL80211_BANDS]; struct wireless_dev *wdev; u8 mac_addr[ETH_ALEN]; u8 mac_addr_mask[ETH_ALEN]; u8 bssid[ETH_ALEN]; struct wiphy *wiphy; unsigned long scan_start; bool no_cck; bool scan_6ghz; bool first_part; u32 n_6ghz_params; struct cfg80211_scan_6ghz_params *scan_6ghz_params; s8 tsf_report_link_id; struct ieee80211_channel *channels[]; };h]hXcstruct cfg80211_scan_request { struct cfg80211_ssid *ssids; int n_ssids; u32 n_channels; const u8 *ie; size_t ie_len; u16 duration; bool duration_mandatory; u32 flags; u32 rates[NUM_NL80211_BANDS]; struct wireless_dev *wdev; u8 mac_addr[ETH_ALEN]; u8 mac_addr_mask[ETH_ALEN]; u8 bssid[ETH_ALEN]; struct wiphy *wiphy; unsigned long scan_start; bool no_cck; bool scan_6ghz; bool first_part; u32 n_6ghz_params; struct cfg80211_scan_6ghz_params *scan_6ghz_params; s8 tsf_report_link_id; struct ieee80211_channel *channels[]; };}hj?sbah}(h]h ]h"]h$]h&]jjuh1j9 ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM3 hjc?ubh)}(h **Members**h]j)}(hj?h]hMembers}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhML hjc?ubj%)}(hhh](j*)}(h/``ssids`` SSIDs to scan for (active scan only) h](j0)}(h ``ssids``h]j,)}(hj?h]hssids}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj?ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM0 hj?ubjJ)}(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?hM0 hj?ubah}(h]h ]h"]h$]h&]uh1jIhj?ubeh}(h]h ]h"]h$]h&]uh1j)hj?hM0 hj?ubj*)}(h``n_ssids`` number of SSIDs h](j0)}(h ``n_ssids``h]j,)}(hj?h]hn_ssids}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj?ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM1 hj?ubjJ)}(hhh]h)}(hnumber of SSIDsh]hnumber of SSIDs}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@hM1 hj@ubah}(h]h ]h"]h$]h&]uh1jIhj?ubeh}(h]h ]h"]h$]h&]uh1j)hj@hM1 hj?ubj*)}(h0``n_channels`` total number of channels to scan h](j0)}(h``n_channels``h]j,)}(hj&@h]h n_channels}(hj(@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj$@ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM3 hj @ubjJ)}(hhh]h)}(h total number of channels to scanh]h total number of channels to scan}(hj?@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;@hM3 hj<@ubah}(h]h ]h"]h$]h&]uh1jIhj @ubeh}(h]h ]h"]h$]h&]uh1j)hj;@hM3 hj?ubj*)}(hM``ie`` optional information element(s) to add into Probe Request or ``NULL`` h](j0)}(h``ie``h]j,)}(hj_@h]hie}(hja@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj]@ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM4 hjY@ubjJ)}(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 }(hjx@hhhNhNubj,)}(h``NULL``h]hNULL}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjx@ubeh}(h]h ]h"]h$]h&]uh1hhjt@hM4 hju@ubah}(h]h ]h"]h$]h&]uh1jIhjY@ubeh}(h]h ]h"]h$]h&]uh1j)hjt@hM4 hj?ubj*)}(h"``ie_len`` length of ie in octets h](j0)}(h ``ie_len``h]j,)}(hj@h]hie_len}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj@ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM5 hj@ubjJ)}(hhh]h)}(hlength of ie in octetsh]hlength of ie in octets}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@hM5 hj@ubah}(h]h ]h"]h$]h&]uh1jIhj@ubeh}(h]h ]h"]h$]h&]uh1j)hj@hM5 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](j0)}(h ``duration``h]j,)}(hj@h]hduration}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj@ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM8 hj@ubjJ)}(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}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj@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.hhM6 hj@ubah}(h]h ]h"]h$]h&]uh1jIhj@ubeh}(h]h ]h"]h$]h&]uh1j)hj@hM8 hj?ubj*)}(ha``duration_mandatory`` if set, the scan duration must be as specified by the ``duration`` field. h](j0)}(h``duration_mandatory``h]j,)}(hj+Ah]hduration_mandatory}(hj-AhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj)Aubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM: hj%AubjJ)}(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 }(hjDAhhhNhNubj,)}(h ``duration``h]hduration}(hjLAhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjDAubh field.}(hjDAhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM9 hjAAubah}(h]h ]h"]h$]h&]uh1jIhj%Aubeh}(h]h ]h"]h$]h&]uh1j)hj@AhM: hj?ubj*)}(hT``flags`` control flags from :c:type:`enum nl80211_scan_flags ` h](j0)}(h ``flags``h]j,)}(hjwAh]hflags}(hjyAhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjuAubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM; hjqAubjJ)}(hhh]h)}(hIcontrol flags from :c:type:`enum nl80211_scan_flags `h](hcontrol flags from }(hjAhhhNhNubh)}(h6:c:type:`enum nl80211_scan_flags `h]j,)}(hjAh]henum nl80211_scan_flags}(hjAhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjAubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_scan_flagsuh1hhjAhM; hjAubeh}(h]h ]h"]h$]h&]uh1hhjAhM; hjAubah}(h]h ]h"]h$]h&]uh1jIhjqAubeh}(h]h ]h"]h$]h&]uh1j)hjAhM; hj?ubj*)}(h5``rates`` bitmap of rates to advertise for each band h](j0)}(h ``rates``h]j,)}(hjAh]hrates}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjAubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM< hjAubjJ)}(hhh]h)}(h*bitmap of rates to advertise for each bandh]h*bitmap of rates to advertise for each band}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhM< hjAubah}(h]h ]h"]h$]h&]uh1jIhjAubeh}(h]h ]h"]h$]h&]uh1j)hjAhM< hj?ubj*)}(h)``wdev`` the wireless device to scan for h](j0)}(h``wdev``h]j,)}(hjBh]hwdev}(hj BhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjBubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM? hjBubjJ)}(hhh]h)}(hthe wireless device to scan forh]hthe wireless device to scan for}(hj!BhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhM? hjBubah}(h]h ]h"]h$]h&]uh1jIhjBubeh}(h]h ]h"]h$]h&]uh1j)hjBhM? hj?ubj*)}(h1``mac_addr`` MAC address used with randomisation h](j0)}(h ``mac_addr``h]j,)}(hjABh]hmac_addr}(hjCBhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj?Bubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMA hj;BubjJ)}(hhh]h)}(h#MAC address used with randomisationh]h#MAC address used with randomisation}(hjZBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVBhMA hjWBubah}(h]h ]h"]h$]h&]uh1jIhj;Bubeh}(h]h ]h"]h$]h&]uh1j)hjVBhMA 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](j0)}(h``mac_addr_mask``h]j,)}(hjzBh]h mac_addr_mask}(hj|BhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjxBubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMD hjtBubjJ)}(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 }(hjBhhhNhNubj)}(h **mac_addr**h]hmac_addr}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMB hjBubah}(h]h ]h"]h$]h&]uh1jIhjtBubeh}(h]h ]h"]h$]h&]uh1j)hjBhMD hj?ubj*)}(h@``bssid`` BSSID to scan for (most commonly, the wildcard BSSID) h](j0)}(h ``bssid``h]j,)}(hjBh]hbssid}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjBubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhML hjBubjJ)}(hhh]h)}(h5BSSID to scan for (most commonly, the wildcard BSSID)h]h5BSSID to scan for (most commonly, the wildcard BSSID)}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhML hjBubah}(h]h ]h"]h$]h&]uh1jIhjBubeh}(h]h ]h"]h$]h&]uh1j)hjBhML hj?ubj*)}(h!``wiphy`` the wiphy this was for h](j0)}(h ``wiphy``h]j,)}(hjBh]hwiphy}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjBubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM= hjBubjJ)}(hhh]h)}(hthe wiphy this was forh]hthe wiphy this was for}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChM= hjCubah}(h]h ]h"]h$]h&]uh1jIhjBubeh}(h]h ]h"]h$]h&]uh1j)hjChM= hj?ubj*)}(h7``scan_start`` time (in jiffies) when the scan started h](j0)}(h``scan_start``h]j,)}(hj4Ch]h scan_start}(hj6ChhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj2Cubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM> hj.CubjJ)}(hhh]h)}(h'time (in jiffies) when the scan startedh]h'time (in jiffies) when the scan started}(hjMChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIChM> hjJCubah}(h]h ]h"]h$]h&]uh1jIhj.Cubeh}(h]h ]h"]h$]h&]uh1j)hjIChM> hj?ubj*)}(hD``no_cck`` used to send probe requests at non CCK rate in 2GHz band h](j0)}(h ``no_cck``h]j,)}(hjmCh]hno_cck}(hjoChhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjkCubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM@ hjgCubjJ)}(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}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChM@ hjCubah}(h]h ]h"]h$]h&]uh1jIhjgCubeh}(h]h ]h"]h$]h&]uh1j)hjChM@ hj?ubj*)}(hY``scan_6ghz`` relevant for split scan request only, true if this is a 6 GHz scan request h](j0)}(h ``scan_6ghz``h]j,)}(hjCh]h scan_6ghz}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjCubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMF hjCubjJ)}(hhh]h)}(hJrelevant for split scan request only, true if this is a 6 GHz scan requesth]hJrelevant for split scan request only, true if this is a 6 GHz scan request}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhME hjCubah}(h]h ]h"]h$]h&]uh1jIhjCubeh}(h]h ]h"]h$]h&]uh1j)hjChMF hj?ubj*)}(h``first_part`` ``true`` if this is the first part of a split scan request or a scan that was not split. May be ``true`` for a **scan_6ghz** scan if no other channels were requested h](j0)}(h``first_part``h]j,)}(hjCh]h first_part}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjCubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMI hjCubjJ)}(hhh]h)}(h``true`` if this is the first part of a split scan request or a scan that was not split. May be ``true`` for a **scan_6ghz** scan if no other channels were requestedh](j,)}(h``true``h]htrue}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjCubhX if this is the first part of a split scan request or a scan that was not split. May be }(hjChhhNhNubj,)}(h``true``h]htrue}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjCubh for a }(hjChhhNhNubj)}(h **scan_6ghz**h]h scan_6ghz}(hj!DhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubh) scan if no other channels were requested}(hjChhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMG hjCubah}(h]h ]h"]h$]h&]uh1jIhjCubeh}(h]h ]h"]h$]h&]uh1j)hjChMI hj?ubj*)}(h)``n_6ghz_params`` number of 6 GHz params h](j0)}(h``n_6ghz_params``h]j,)}(hjLDh]h n_6ghz_params}(hjNDhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjJDubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMJ hjFDubjJ)}(hhh]h)}(hnumber of 6 GHz paramsh]hnumber of 6 GHz params}(hjeDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjaDhMJ hjbDubah}(h]h ]h"]h$]h&]uh1jIhjFDubeh}(h]h ]h"]h$]h&]uh1j)hjaDhMJ hj?ubj*)}(h"``scan_6ghz_params`` 6 GHz params h](j0)}(h``scan_6ghz_params``h]j,)}(hjDh]hscan_6ghz_params}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjDubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMK hjDubjJ)}(hhh]h)}(h 6 GHz paramsh]h 6 GHz params}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDhMK hjDubah}(h]h ]h"]h$]h&]uh1jIhjDubeh}(h]h ]h"]h$]h&]uh1j)hjDhMK 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](j0)}(h``tsf_report_link_id``h]j,)}(hjDh]htsf_report_link_id}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjDubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMN hjDubjJ)}(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.}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMM hjDubah}(h]h ]h"]h$]h&]uh1jIhjDubeh}(h]h ]h"]h$]h&]uh1j)hjDhMN hj?ubj*)}(h!``channels`` channels to scan on.h](j0)}(h ``channels``h]j,)}(hjDh]hchannels}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjDubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM1 hjDubjJ)}(hhh]h)}(hchannels to scan on.h]hchannels to scan on.}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM2 hjEubah}(h]h ]h"]h$]h&]uh1jIhjDubeh}(h]h ]h"]h$]h&]uh1j)hj EhM1 hj?ubeh}(h]h ]h"]h$]h&]uh1j$hjc?ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjl=hhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jscfg80211_inform_bss (C struct)c.cfg80211_inform_bsshNtauh1jfhjl=hhhNhNubjx)}(hhh](j})}(hcfg80211_inform_bssh]j)}(hstruct cfg80211_inform_bssh](j)}(hjh]hstruct}(hjREhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNEhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM8 ubj)}(h h]h }(hj`EhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNEhhhj_EhM8 ubj)}(hcfg80211_inform_bssh]j)}(hjLEh]hcfg80211_inform_bss}(hjrEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnEubah}(h]h ](jjeh"]h$]h&]jjuh1jhjNEhhhj_EhM8 ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjJEhhhj_EhM8 ubah}(h]jEEah ](jjeh"]h$]h&]jj)jhuh1j|hj_EhM8 hjGEhhubj)}(hhh]h)}(hBSS inform datah]hBSS inform data}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjEhhubah}(h]h ]h"]h$]h&]uh1jhjGEhhhj_EhM8 ubeh}(h]h ](j8structeh"]h$]h&]jj8jjEjjEjjjuh1jwhhhjl=hNhNubj)}(hX7**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}(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 hjEubj: )}(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; };}hjEsbah}(h]h ]h"]h$]h&]jjuh1j9 ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjEubh)}(h **Members**h]j)}(hjEh]hMembers}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjEubj%)}(hhh](j*)}(h+``chan`` channel the frame was received on h](j0)}(h``chan``h]j,)}(hjFh]hchan}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjEubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjEubjJ)}(hhh]h)}(h!channel the frame was received onh]h!channel the frame was received on}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhM hjFubah}(h]h ]h"]h$]h&]uh1jIhjEubeh}(h]h ]h"]h$]h&]uh1j)hjFhM hjEubj*)}(hG``signal`` signal strength value, according to the wiphy's signal type h](j0)}(h ``signal``h]j,)}(hj:Fh]hsignal}(hj` h](j0)}(h ``use_for``h]j,)}(hj(Hh]huse_for}(hj*HhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj&Hubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj"HubjJ)}(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 }(hjAHhhhNhNubh)}(h8:c:type:`enum nl80211_bss_use_for `h]j,)}(hjKHh]henum nl80211_bss_use_for}(hjMHhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjIHubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_bss_use_foruh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjAHubeh}(h]h ]h"]h$]h&]uh1hhjhHhM hj>Hubah}(h]h ]h"]h$]h&]uh1jIhj"Hubeh}(h]h ]h"]h$]h&]uh1j)hj=HhM hjEubj*)}(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](j0)}(h``cannot_use_reasons``h]j,)}(hjHh]hcannot_use_reasons}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjHubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hj{HubjJ)}(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 }(hjHhhhNhNubj)}(h**restrict_use**h]h restrict_use}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubh is set and }(hjHhhhNhNubj)}(h **use_for**h]huse_for}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubh8 is zero (empty); may be 0 for unspecified reasons; see }(hjHhhhNhNubh)}(hN:c:type:`enum nl80211_bss_cannot_use_reasons `h]j,)}(hjHh]h#enum nl80211_bss_cannot_use_reasons}(hjHhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjHubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_bss_cannot_use_reasonsuh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjHubeh}(h]h ]h"]h$]h&]uh1hhjHhM hjHubah}(h]h ]h"]h$]h&]uh1jIhj{Hubeh}(h]h ]h"]h$]h&]uh1j)hjHhM hjEubj*)}(h8``drv_data`` Data to be passed through to **inform_bss**h](j0)}(h ``drv_data``h]j,)}(hjHh]hdrv_data}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjHubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjHubjJ)}(hhh]h)}(h+Data to be passed through to **inform_bss**h](hData to be passed through to }(hjIhhhNhNubj)}(h**inform_bss**h]h inform_bss}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjIubah}(h]h ]h"]h$]h&]uh1jIhjHubeh}(h]h ]h"]h$]h&]uh1j)hjIhM hjEubeh}(h]h ]h"]h$]h&]uh1j$hjEubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjl=hhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jscfg80211_bss (C struct)c.cfg80211_bsshNtauh1jfhjl=hhhNhNubjx)}(hhh](j})}(h cfg80211_bssh]j)}(hstruct cfg80211_bssh](j)}(hjh]hstruct}(hjfIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbIhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM" ubj)}(h h]h }(hjtIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbIhhhjsIhM" ubj)}(h cfg80211_bssh]j)}(hj`Ih]h cfg80211_bss}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubah}(h]h ](jjeh"]h$]h&]jjuh1jhjbIhhhjsIhM" ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj^IhhhjsIhM" ubah}(h]jYIah ](jjeh"]h$]h&]jj)jhuh1j|hjsIhM" hj[Ihhubj)}(hhh]h)}(hBSS descriptionh]hBSS description}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM= hjIhhubah}(h]h ]h"]h$]h&]uh1jhj[IhhhjsIhM" ubeh}(h]h ](j8structeh"]h$]h&]jj8jjIjjIjjjuh1jwhhhjl=hNhNubj)}(hX **Definition**:: struct cfg80211_bss { struct ieee80211_channel *channel; const struct cfg80211_bss_ies *ies; const struct cfg80211_bss_ies *beacon_ies; const struct cfg80211_bss_ies *proberesp_ies; struct cfg80211_bss *hidden_beacon_bss; struct cfg80211_bss *transmitted_bss; struct list_head nontrans_list; s32 signal; u64 ts_boottime; u16 beacon_interval; u16 capability; u8 bssid[ETH_ALEN]; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; u8 proberesp_ecsa_stuck:1; u8 bssid_index; u8 max_bssid_indicator; u8 use_for; u8 cannot_use_reasons; u8 priv[]; }; **Members** ``channel`` channel this BSS is on ``ies`` the information elements (Note that there is no guarantee that these are well-formed!); this is a pointer to either the beacon_ies or proberesp_ies depending on whether Probe Response frame has been received. It is always non-``NULL``. ``beacon_ies`` the information elements from the last Beacon frame (implementation note: if **hidden_beacon_bss** is set this struct doesn't own the beacon_ies, but they're just pointers to the ones from the **hidden_beacon_bss** struct) ``proberesp_ies`` the information elements from the last Probe Response frame ``hidden_beacon_bss`` in case this BSS struct represents a probe response from a BSS that hides the SSID in its beacon, this points to the BSS struct that holds the beacon data. **beacon_ies** is still valid, of course, and points to the same data as hidden_beacon_bss->beacon_ies in that case. ``transmitted_bss`` pointer to the transmitted BSS, if this is a non-transmitted one (multi-BSSID support) ``nontrans_list`` list of non-transmitted BSS, if this is a transmitted one (multi-BSSID support) ``signal`` signal strength value (type depends on the wiphy's signal_type) ``ts_boottime`` timestamp of the last BSS update in nanoseconds since boot ``beacon_interval`` the beacon interval as from the frame ``capability`` the capability field in host byte order ``bssid`` BSSID of the BSS ``chains`` bitmask for filled values in **chain_signal**. ``chain_signal`` per-chain signal strength of last received BSS in dBm. ``proberesp_ecsa_stuck`` ECSA element is stuck in the Probe Response frame, cannot rely on it having valid data ``bssid_index`` index in the multiple BSS set ``max_bssid_indicator`` max number of members in the BSS set ``use_for`` bitmap of possible usage for this BSS, see :c:type:`enum nl80211_bss_use_for ` ``cannot_use_reasons`` the reasons (bitmap) for not being able to connect, if **restrict_use** is set and **use_for** is zero (empty); may be 0 for unspecified reasons; see :c:type:`enum nl80211_bss_cannot_use_reasons ` ``priv`` private area for driver use, has at least wiphy->bss_priv_size bytesh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubh:}(hjIhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMA hjIubj: )}(hXostruct cfg80211_bss { struct ieee80211_channel *channel; const struct cfg80211_bss_ies *ies; const struct cfg80211_bss_ies *beacon_ies; const struct cfg80211_bss_ies *proberesp_ies; struct cfg80211_bss *hidden_beacon_bss; struct cfg80211_bss *transmitted_bss; struct list_head nontrans_list; s32 signal; u64 ts_boottime; u16 beacon_interval; u16 capability; u8 bssid[ETH_ALEN]; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; u8 proberesp_ecsa_stuck:1; u8 bssid_index; u8 max_bssid_indicator; u8 use_for; u8 cannot_use_reasons; u8 priv[]; };h]hXostruct cfg80211_bss { struct ieee80211_channel *channel; const struct cfg80211_bss_ies *ies; const struct cfg80211_bss_ies *beacon_ies; const struct cfg80211_bss_ies *proberesp_ies; struct cfg80211_bss *hidden_beacon_bss; struct cfg80211_bss *transmitted_bss; struct list_head nontrans_list; s32 signal; u64 ts_boottime; u16 beacon_interval; u16 capability; u8 bssid[ETH_ALEN]; u8 chains; s8 chain_signal[IEEE80211_MAX_CHAINS]; u8 proberesp_ecsa_stuck:1; u8 bssid_index; u8 max_bssid_indicator; u8 use_for; u8 cannot_use_reasons; u8 priv[]; };}hjIsbah}(h]h ]h"]h$]h&]jjuh1j9 ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMC hjIubh)}(h **Members**h]j)}(hjIh]hMembers}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMZ hjIubj%)}(hhh](j*)}(h#``channel`` channel this BSS is on h](j0)}(h ``channel``h]j,)}(hjJh]hchannel}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjJubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMC hjJubjJ)}(hhh]h)}(hchannel this BSS is onh]hchannel this BSS is on}(hj.JhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*JhMC hj+Jubah}(h]h ]h"]h$]h&]uh1jIhjJubeh}(h]h ]h"]h$]h&]uh1j)hj*JhMC hj Jubj*)}(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](j0)}(h``ies``h]j,)}(hjNJh]hies}(hjPJhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjLJubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMJ hjHJubjJ)}(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-}(hjgJhhhNhNubj,)}(h``NULL``h]hNULL}(hjoJhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjgJubh.}(hjgJhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMG hjdJubah}(h]h ]h"]h$]h&]uh1jIhjHJubeh}(h]h ]h"]h$]h&]uh1j)hjcJhMJ hj Jubj*)}(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](j0)}(h``beacon_ies``h]j,)}(hjJh]h beacon_ies}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjJubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMN hjJubjJ)}(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 }(hjJhhhNhNubj)}(h**hidden_beacon_bss**h]hhidden_beacon_bss}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubhc is set this struct doesn’t own the beacon_ies, but they’re just pointers to the ones from the }(hjJhhhNhNubj)}(h**hidden_beacon_bss**h]hhidden_beacon_bss}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubh struct)}(hjJhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMK hjJubah}(h]h ]h"]h$]h&]uh1jIhjJubeh}(h]h ]h"]h$]h&]uh1j)hjJhMN hj Jubj*)}(hN``proberesp_ies`` the information elements from the last Probe Response frame h](j0)}(h``proberesp_ies``h]j,)}(hjJh]h proberesp_ies}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjJubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMO hjJubjJ)}(hhh]h)}(h;the information elements from the last Probe Response frameh]h;the information elements from the last Probe Response frame}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj KhMO hjKubah}(h]h ]h"]h$]h&]uh1jIhjJubeh}(h]h ]h"]h$]h&]uh1j)hj KhMO hj Jubj*)}(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](j0)}(h``hidden_beacon_bss``h]j,)}(hj1Kh]hhidden_beacon_bss}(hj3KhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj/Kubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMU hj+KubjJ)}(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. }(hjJKhhhNhNubj)}(h**beacon_ies**h]h beacon_ies}(hjRKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJKubhf is still valid, of course, and points to the same data as hidden_beacon_bss->beacon_ies in that case.}(hjJKhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMR hjGKubah}(h]h ]h"]h$]h&]uh1jIhj+Kubeh}(h]h ]h"]h$]h&]uh1j)hjFKhMU hj Jubj*)}(hk``transmitted_bss`` pointer to the transmitted BSS, if this is a non-transmitted one (multi-BSSID support) h](j0)}(h``transmitted_bss``h]j,)}(hj}Kh]htransmitted_bss}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj{Kubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMW hjwKubjJ)}(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)}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMV hjKubah}(h]h ]h"]h$]h&]uh1jIhjwKubeh}(h]h ]h"]h$]h&]uh1j)hjKhMW hj Jubj*)}(hb``nontrans_list`` list of non-transmitted BSS, if this is a transmitted one (multi-BSSID support) h](j0)}(h``nontrans_list``h]j,)}(hjKh]h nontrans_list}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjKubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMY hjKubjJ)}(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)}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMX hjKubah}(h]h ]h"]h$]h&]uh1jIhjKubeh}(h]h ]h"]h$]h&]uh1j)hjKhMY hj Jubj*)}(hK``signal`` signal strength value (type depends on the wiphy's signal_type) h](j0)}(h ``signal``h]j,)}(hjKh]hsignal}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjKubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMZ hjKubjJ)}(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)}(hj LhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMZ hjLubah}(h]h ]h"]h$]h&]uh1jIhjKubeh}(h]h ]h"]h$]h&]uh1j)hjLhMZ hj Jubj*)}(hK``ts_boottime`` timestamp of the last BSS update in nanoseconds since boot h](j0)}(h``ts_boottime``h]j,)}(hj*Lh]h ts_boottime}(hj,LhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj(Lubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM[ hj$LubjJ)}(hhh]h)}(h:timestamp of the last BSS update in nanoseconds since booth]h:timestamp of the last BSS update in nanoseconds since boot}(hjCLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?LhM[ hj@Lubah}(h]h ]h"]h$]h&]uh1jIhj$Lubeh}(h]h ]h"]h$]h&]uh1j)hj?LhM[ hj Jubj*)}(h:``beacon_interval`` the beacon interval as from the frame h](j0)}(h``beacon_interval``h]j,)}(hjcLh]hbeacon_interval}(hjeLhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjaLubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhME hj]LubjJ)}(hhh]h)}(h%the beacon interval as from the frameh]h%the beacon interval as from the frame}(hj|LhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxLhME hjyLubah}(h]h ]h"]h$]h&]uh1jIhj]Lubeh}(h]h ]h"]h$]h&]uh1j)hjxLhME hj Jubj*)}(h7``capability`` the capability field in host byte order h](j0)}(h``capability``h]j,)}(hjLh]h capability}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjLubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMF hjLubjJ)}(hhh]h)}(h'the capability field in host byte orderh]h'the capability field in host byte order}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMF hjLubah}(h]h ]h"]h$]h&]uh1jIhjLubeh}(h]h ]h"]h$]h&]uh1j)hjLhMF hj Jubj*)}(h``bssid`` BSSID of the BSS h](j0)}(h ``bssid``h]j,)}(hjLh]hbssid}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjLubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMD hjLubjJ)}(hhh]h)}(hBSSID of the BSSh]hBSSID of the BSS}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMD hjLubah}(h]h ]h"]h$]h&]uh1jIhjLubeh}(h]h ]h"]h$]h&]uh1j)hjLhMD hj Jubj*)}(h:``chains`` bitmask for filled values in **chain_signal**. h](j0)}(h ``chains``h]j,)}(hjMh]hchains}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj Mubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM\ hjMubjJ)}(hhh]h)}(h.bitmask for filled values in **chain_signal**.h](hbitmask for filled values in }(hj'MhhhNhNubj)}(h**chain_signal**h]h chain_signal}(hj/MhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'Mubh.}(hj'MhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj#MhM\ hj$Mubah}(h]h ]h"]h$]h&]uh1jIhjMubeh}(h]h ]h"]h$]h&]uh1j)hj#MhM\ hj Jubj*)}(hH``chain_signal`` per-chain signal strength of last received BSS in dBm. h](j0)}(h``chain_signal``h]j,)}(hjYMh]h chain_signal}(hj[MhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjWMubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM] hjSMubjJ)}(hhh]h)}(h6per-chain signal strength of last received BSS in dBm.h]h6per-chain signal strength of last received BSS in dBm.}(hjrMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnMhM] hjoMubah}(h]h ]h"]h$]h&]uh1jIhjSMubeh}(h]h ]h"]h$]h&]uh1j)hjnMhM] hj Jubj*)}(hp``proberesp_ecsa_stuck`` ECSA element is stuck in the Probe Response frame, cannot rely on it having valid data h](j0)}(h``proberesp_ecsa_stuck``h]j,)}(hjMh]hproberesp_ecsa_stuck}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjMubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMQ hjMubjJ)}(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}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMP hjMubah}(h]h ]h"]h$]h&]uh1jIhjMubeh}(h]h ]h"]h$]h&]uh1j)hjMhMQ hj Jubj*)}(h.``bssid_index`` index in the multiple BSS set h](j0)}(h``bssid_index``h]j,)}(hjMh]h bssid_index}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjMubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM^ hjMubjJ)}(hhh]h)}(hindex in the multiple BSS seth]hindex in the multiple BSS set}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMhM^ hjMubah}(h]h ]h"]h$]h&]uh1jIhjMubeh}(h]h ]h"]h$]h&]uh1j)hjMhM^ hj Jubj*)}(h=``max_bssid_indicator`` max number of members in the BSS set h](j0)}(h``max_bssid_indicator``h]j,)}(hjNh]hmax_bssid_indicator}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjNubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM_ hjMubjJ)}(hhh]h)}(h$max number of members in the BSS seth]h$max number of members in the BSS set}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjNhM_ hjNubah}(h]h ]h"]h$]h&]uh1jIhjMubeh}(h]h ]h"]h$]h&]uh1j)hjNhM_ hj Jubj*)}(hp``use_for`` bitmap of possible usage for this BSS, see :c:type:`enum nl80211_bss_use_for ` h](j0)}(h ``use_for``h]j,)}(hj>Nh]huse_for}(hj@NhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj`h](h+bitmap of possible usage for this BSS, see }(hjWNhhhNhNubh)}(h8:c:type:`enum nl80211_bss_use_for `h]j,)}(hjaNh]henum nl80211_bss_use_for}(hjcNhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hj_Nubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_bss_use_foruh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM` hjWNubeh}(h]h ]h"]h$]h&]uh1hhj~NhM` hjTNubah}(h]h ]h"]h$]h&]uh1jIhj8Nubeh}(h]h ]h"]h$]h&]uh1j)hjSNhMa hj Jubj*)}(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](j0)}(h``cannot_use_reasons``h]j,)}(hjNh]hcannot_use_reasons}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjNubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMd hjNubjJ)}(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 }(hjNhhhNhNubj)}(h**restrict_use**h]h restrict_use}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubh is set and }(hjNhhhNhNubj)}(h **use_for**h]huse_for}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubh8 is zero (empty); may be 0 for unspecified reasons; see }(hjNhhhNhNubh)}(hN:c:type:`enum nl80211_bss_cannot_use_reasons `h]j,)}(hjNh]h#enum nl80211_bss_cannot_use_reasons}(hjNhhhNhNubah}(h]h ](j7j8c-typeeh"]h$]h&]uh1j+hjNubah}(h]h ]h"]h$]h&]refdocjD refdomainj8reftypetype refexplicitrefwarnj j jJnl80211_bss_cannot_use_reasonsuh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMb hjNubeh}(h]h ]h"]h$]h&]uh1hhjNhMb hjNubah}(h]h ]h"]h$]h&]uh1jIhjNubeh}(h]h ]h"]h$]h&]uh1j)hjNhMd hj Jubj*)}(hM``priv`` private area for driver use, has at least wiphy->bss_priv_size bytesh](j0)}(h``priv``h]j,)}(hjOh]hpriv}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjOubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMd hjOubjJ)}(hhh]h)}(hDprivate area for driver use, has at least wiphy->bss_priv_size bytesh]hDprivate area for driver use, has at least wiphy->bss_priv_size bytes}(hj-OhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMe hj*Oubah}(h]h ]h"]h$]h&]uh1jIhjOubeh}(h]h ]h"]h$]h&]uh1j)hj)OhMd hj Jubeh}(h]h ]h"]h$]h&]uh1j$hjIubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjl=hhhNhNubh)}(h**Description**h]j)}(hjWOh]h Description}(hjYOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUOubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMh hjl=hhubh)}(hfThis structure describes a BSS (which may also be a mesh network) for use in scan results and similar.h]hfThis structure describes a BSS (which may also be a mesh network) for use in scan results and similar.}(hjmOhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM> hjl=hhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js!ieee80211_bss_get_ie (C function)c.ieee80211_bss_get_iehNtauh1jfhjl=hhhNhNubjx)}(hhh](j})}(hAconst u8 * ieee80211_bss_get_ie (struct cfg80211_bss *bss, u8 id)h]j)}(h?const u8 *ieee80211_bss_get_ie(struct cfg80211_bss *bss, u8 id)h](j)}(hjIh]hconst}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM ubj)}(h h]h }(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOhhhjOhM ubh)}(hhh]j)}(hu8h]hu8}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjOmodnameN classnameNj j )}j ]jf)}j^ieee80211_bss_get_iesbc.ieee80211_bss_get_ieasbuh1hhjOhhhjOhM ubj)}(h h]h }(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOhhhjOhM ubjz)}(hj}h]h*}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjOhhhjOhM ubj)}(hieee80211_bss_get_ieh]j)}(hjOh]hieee80211_bss_get_ie}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubah}(h]h ](jjeh"]h$]h&]jjuh1jhjOhhhjOhM ubj)}(h!(struct cfg80211_bss *bss, u8 id)h](j%)}(hstruct cfg80211_bss *bssh](j)}(hjh]hstruct}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj Pubj)}(h h]h }(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj Pubh)}(hhh]j)}(h cfg80211_bssh]h cfg80211_bss}(hj-PhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*Pubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj/PmodnameN classnameNj j )}j ]jOc.ieee80211_bss_get_ieasbuh1hhj Pubj)}(h h]h }(hjKPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj Pubjz)}(hj}h]h*}(hjYPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj Pubj)}(hbssh]hbss}(hjfPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj Pubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjPubj%)}(hu8 idh](h)}(hhh]j)}(hu8h]hu8}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjPmodnameN classnameNj j )}j ]jOc.ieee80211_bss_get_ieasbuh1hhj{Pubj)}(h h]h }(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{Pubj)}(hidh]hid}(hjPhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{Pubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjPubeh}(h]h ]h"]h$]h&]jjuh1jhjOhhhjOhM ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjOhhhjOhM ubah}(h]jOah ](jjeh"]h$]h&]jj)jhuh1j|hjOhM hjOhhubj)}(hhh]h)}(hfind IE with given IDh]hfind IE with given ID}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjPhhubah}(h]h ]h"]h$]h&]uh1jhjOhhhjOhM ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjPjjPjjjuh1jwhhhjl=hNhNubj)}(hX**Parameters** ``struct cfg80211_bss *bss`` the bss to search ``u8 id`` the element ID **Description** Note that the return value is an RCU-protected pointer, so rcu_read_lock() must be held when calling this function. **Return** ``NULL`` if not found.h](h)}(h**Parameters**h]j)}(hjPh]h Parameters}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjPubj%)}(hhh](j*)}(h/``struct cfg80211_bss *bss`` the bss to search h](j0)}(h``struct cfg80211_bss *bss``h]j,)}(hjQh]hstruct cfg80211_bss *bss}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjQubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjQubjJ)}(hhh]h)}(hthe bss to searchh]hthe bss to search}(hj2QhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.QhM hj/Qubah}(h]h ]h"]h$]h&]uh1jIhjQubeh}(h]h ]h"]h$]h&]uh1j)hj.QhM hjQubj*)}(h``u8 id`` the element ID h](j0)}(h ``u8 id``h]j,)}(hjRQh]hu8 id}(hjTQhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjPQubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjLQubjJ)}(hhh]h)}(hthe element IDh]hthe element ID}(hjkQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjgQhM hjhQubah}(h]h ]h"]h$]h&]uh1jIhjLQubeh}(h]h ]h"]h$]h&]uh1j)hjgQhM hjQubeh}(h]h ]h"]h$]h&]uh1j$hjPubh)}(h**Description**h]j)}(hjQh]h Description}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjPubh)}(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.}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjPubh)}(h **Return**h]j)}(hjQh]hReturn}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjPubh)}(h``NULL`` if not found.h](j,)}(h``NULL``h]hNULL}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjQubh if not found.}(hjQhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM hjPubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjl=hhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jscfg80211_find_ie (C function)c.cfg80211_find_iehNtauh1jfhjl=hhhNhNubjx)}(hhh](j})}(hhjrYubh)}(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.}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM=hjrYubh)}(h **Return**h]j)}(hjZh]hReturn}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM@hjrYubh)}(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 }(hjZhhhNhNubj,)}(h``NULL``h]hNULL}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjZubh on error.}(hjZhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMAhjrYubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjl=hhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js%cfg80211_inform_bss_data (C function)c.cfg80211_inform_bss_datahNtauh1jfhjl=hhhNhNubjx)}(hhh](j})}(hstruct cfg80211_bss * cfg80211_inform_bss_data (struct wiphy *wiphy, struct cfg80211_inform_bss *data, enum cfg80211_bss_frame_type ftype, const u8 *bssid, u64 tsf, u16 capability, u16 beacon_interval, const u8 *ie, size_t ielen, gfp_t gfp)h]j)}(hstruct cfg80211_bss *cfg80211_inform_bss_data(struct wiphy *wiphy, struct cfg80211_inform_bss *data, enum cfg80211_bss_frame_type ftype, const u8 *bssid, u64 tsf, u16 capability, u16 beacon_interval, const u8 *ie, size_t ielen, gfp_t gfp)h](j)}(hjh]hstruct}(hj4[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0[hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMubj)}(h h]h }(hjB[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0[hhhjA[hMubh)}(hhh]j)}(h cfg80211_bssh]h cfg80211_bss}(hjS[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjP[ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjU[modnameN classnameNj j )}j ]jf)}j^cfg80211_inform_bss_datasbc.cfg80211_inform_bss_dataasbuh1hhj0[hhhjA[hMubj)}(h h]h }(hjt[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0[hhhjA[hMubjz)}(hj}h]h*}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj0[hhhjA[hMubj)}(hcfg80211_inform_bss_datah]j)}(hjq[h]hcfg80211_inform_bss_data}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ubah}(h]h ](jjeh"]h$]h&]jjuh1jhj0[hhhjA[hMubj)}(h(struct wiphy *wiphy, struct cfg80211_inform_bss *data, enum cfg80211_bss_frame_type ftype, const u8 *bssid, u64 tsf, u16 capability, u16 beacon_interval, const u8 *ie, size_t ielen, gfp_t gfp)h](j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[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&] refdomainj8reftypej^ reftargetj[modnameN classnameNj j )}j ]jo[c.cfg80211_inform_bss_dataasbuh1hhj[ubj)}(h h]h }(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ubjz)}(hj}h]h*}(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj[ubj)}(hwiphyh]hwiphy}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj[ubj%)}(h struct cfg80211_inform_bss *datah](j)}(hjh]hstruct}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubj)}(h h]h }(hj+\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubh)}(hhh]j)}(hcfg80211_inform_bssh]hcfg80211_inform_bss}(hj<\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj9\ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj>\modnameN classnameNj j )}j ]jo[c.cfg80211_inform_bss_dataasbuh1hhj\ubj)}(h h]h }(hjZ\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubjz)}(hj}h]h*}(hjh\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj\ubj)}(hdatah]hdata}(hju\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj[ubj%)}(h"enum cfg80211_bss_frame_type ftypeh](j)}(hjh]henum}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubj)}(h h]h }(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubh)}(hhh]j)}(hcfg80211_bss_frame_typeh]hcfg80211_bss_frame_type}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj\modnameN classnameNj j )}j ]jo[c.cfg80211_inform_bss_dataasbuh1hhj\ubj)}(h h]h }(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubj)}(hftypeh]hftype}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj[ubj%)}(hconst u8 *bssidh](j)}(hjIh]hconst}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\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&] refdomainj8reftypej^ reftargetj]modnameN classnameNj j )}j ]jo[c.cfg80211_inform_bss_dataasbuh1hhj\ubj)}(h h]h }(hj-]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubjz)}(hj}h]h*}(hj;]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj\ubj)}(hbssidh]hbssid}(hjH]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj[ubj%)}(hu64 tsfh](h)}(hhh]j)}(hu64h]hu64}(hjd]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhja]ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjf]modnameN classnameNj j )}j ]jo[c.cfg80211_inform_bss_dataasbuh1hhj]]ubj)}(h h]h }(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]]ubj)}(htsfh]htsf}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]]ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj[ubj%)}(hu16 capabilityh](h)}(hhh]j)}(hu16h]hu16}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj]modnameN classnameNj j )}j ]jo[c.cfg80211_inform_bss_dataasbuh1hhj]ubj)}(h h]h }(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubj)}(h capabilityh]h capability}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj[ubj%)}(hu16 beacon_intervalh](h)}(hhh]j)}(hu16h]hu16}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj]modnameN classnameNj j )}j ]jo[c.cfg80211_inform_bss_dataasbuh1hhj]ubj)}(h h]h }(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubj)}(hbeacon_intervalh]hbeacon_interval}(hj ^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj[ubj%)}(h const u8 *ieh](j)}(hjIh]hconst}(hj9^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5^ubj)}(h h]h }(hjF^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5^ubh)}(hhh]j)}(hu8h]hu8}(hjW^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjT^ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjY^modnameN classnameNj j )}j ]jo[c.cfg80211_inform_bss_dataasbuh1hhj5^ubj)}(h h]h }(hju^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5^ubjz)}(hj}h]h*}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj5^ubj)}(hieh]hie}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5^ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj[ubj%)}(h size_t ielenh](h)}(hhh]j)}(hsize_th]hsize_t}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj^modnameN classnameNj j )}j ]jo[c.cfg80211_inform_bss_dataasbuh1hhj^ubj)}(h h]h }(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubj)}(hielenh]hielen}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj[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&] refdomainj8reftypej^ reftargetj^modnameN classnameNj j )}j ]jo[c.cfg80211_inform_bss_dataasbuh1hhj^ubj)}(h h]h }(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubj)}(hgfph]hgfp}(hj _hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj[ubeh}(h]h ]h"]h$]h&]jjuh1jhj0[hhhjA[hMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj,[hhhjA[hMubah}(h]j'[ah ](jjeh"]h$]h&]jj)jhuh1j|hjA[hMhj)[hhubj)}(hhh]h)}(hinform cfg80211 of a new BSSh]hinform cfg80211 of a new BSS}(hjJ_hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjG_hhubah}(h]h ]h"]h$]h&]uh1jhj)[hhhjA[hMubeh}(h]h ](j8functioneh"]h$]h&]jj8jjb_jjb_jjjuh1jwhhhjl=hNhNubj)}(hX **Parameters** ``struct wiphy *wiphy`` the wiphy reporting the BSS ``struct cfg80211_inform_bss *data`` the BSS metadata ``enum cfg80211_bss_frame_type ftype`` frame type (if known) ``const u8 *bssid`` the BSSID of the BSS ``u64 tsf`` the TSF sent by the peer in the beacon/probe response (or 0) ``u16 capability`` the capability field sent by the peer ``u16 beacon_interval`` the beacon interval announced by the peer ``const u8 *ie`` additional IEs sent by the peer ``size_t ielen`` length of the additional IEs ``gfp_t gfp`` context flags **Description** This informs cfg80211 that BSS information was found and the BSS should be updated/added. **Return** A referenced struct, must be released with cfg80211_put_bss()! Or ``NULL`` on error.h](h)}(h**Parameters**h]j)}(hjl_h]h Parameters}(hjn_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjj_ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhjf_ubj%)}(hhh](j*)}(h4``struct wiphy *wiphy`` the wiphy reporting the BSS h](j0)}(h``struct wiphy *wiphy``h]j,)}(hj_h]hstruct wiphy *wiphy}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj_ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj_ubjJ)}(hhh]h)}(hthe wiphy reporting the BSSh]hthe wiphy reporting the BSS}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hMhj_ubah}(h]h ]h"]h$]h&]uh1jIhj_ubeh}(h]h ]h"]h$]h&]uh1j)hj_hMhj_ubj*)}(h6``struct cfg80211_inform_bss *data`` the BSS metadata h](j0)}(h$``struct cfg80211_inform_bss *data``h]j,)}(hj_h]h struct cfg80211_inform_bss *data}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj_ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj_ubjJ)}(hhh]h)}(hthe BSS metadatah]hthe BSS metadata}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hMhj_ubah}(h]h ]h"]h$]h&]uh1jIhj_ubeh}(h]h ]h"]h$]h&]uh1j)hj_hMhj_ubj*)}(h=``enum cfg80211_bss_frame_type ftype`` frame type (if known) h](j0)}(h&``enum cfg80211_bss_frame_type ftype``h]j,)}(hj_h]h"enum cfg80211_bss_frame_type ftype}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj_ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj_ubjJ)}(hhh]h)}(hframe type (if known)h]hframe type (if known)}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hMhj`ubah}(h]h ]h"]h$]h&]uh1jIhj_ubeh}(h]h ]h"]h$]h&]uh1j)hj`hMhj_ubj*)}(h)``const u8 *bssid`` the BSSID of the BSS h](j0)}(h``const u8 *bssid``h]j,)}(hj6`h]hconst u8 *bssid}(hj8`hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj4`ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhj0`ubjJ)}(hhh]h)}(hthe BSSID of the BSSh]hthe BSSID of the BSS}(hjO`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjK`hMhjL`ubah}(h]h ]h"]h$]h&]uh1jIhj0`ubeh}(h]h ]h"]h$]h&]uh1j)hjK`hMhj_ubj*)}(hI``u64 tsf`` the TSF sent by the peer in the beacon/probe response (or 0) h](j0)}(h ``u64 tsf``h]j,)}(hjo`h]hu64 tsf}(hjq`hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjm`ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhMhji`ubjJ)}(hhh]h)}(hchhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjbubj)}(hbssh]hbss}(hjKchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjzbubeh}(h]h ]h"]h$]h&]jjuh1jhjAbhhhjSbhM+ ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj=bhhhjSbhM+ ubah}(h]j8bah ](jjeh"]h$]h&]jj)jhuh1j|hjSbhM+ hj:bhhubj)}(hhh]h)}(h(unlink BSS from internal data structuresh]h(unlink BSS from internal data structures}(hjuchhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM+ hjrchhubah}(h]h ]h"]h$]h&]uh1jhj:bhhhjSbhM+ ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjcjjcjjjuh1jwhhhjl=hNhNubj)}(hX~**Parameters** ``struct wiphy *wiphy`` the wiphy ``struct cfg80211_bss *bss`` the bss to remove **Description** This function removes the given BSS from the internal data structures thereby making it no longer show up in scan results etc. Use this function when you detect a BSS is gone. Normally BSSes will also time out, so it is not necessary to use this function at all.h](h)}(h**Parameters**h]j)}(hjch]h Parameters}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM/ hjcubj%)}(hhh](j*)}(h"``struct wiphy *wiphy`` the wiphy h](j0)}(h``struct wiphy *wiphy``h]j,)}(hjch]hstruct wiphy *wiphy}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjcubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM, hjcubjJ)}(hhh]h)}(h the wiphyh]h the wiphy}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchM, hjcubah}(h]h ]h"]h$]h&]uh1jIhjcubeh}(h]h ]h"]h$]h&]uh1j)hjchM, hjcubj*)}(h/``struct cfg80211_bss *bss`` the bss to remove h](j0)}(h``struct cfg80211_bss *bss``h]j,)}(hjch]hstruct cfg80211_bss *bss}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjcubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM- hjcubjJ)}(hhh]h)}(hthe bss to removeh]hthe bss to remove}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdhM- hjdubah}(h]h ]h"]h$]h&]uh1jIhjcubeh}(h]h ]h"]h$]h&]uh1j)hjdhM- hjcubeh}(h]h ]h"]h$]h&]uh1j$hjcubh)}(h**Description**h]j)}(hj*dh]h Description}(hj,dhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(dubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM/ hjcubh)}(hXThis function removes the given BSS from the internal data structures thereby making it no longer show up in scan results etc. Use this function when you detect a BSS is gone. Normally BSSes will also time out, so it is not necessary to use this function at all.h]hXThis function removes the given BSS from the internal data structures thereby making it no longer show up in scan results etc. Use this function when you detect a BSS is gone. Normally BSSes will also time out, so it is not necessary to use this function at all.}(hj@dhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:102: ./include/net/cfg80211.hhM. hjcubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjl=hhhNhNubeh}(h]scanning-and-bss-list-handlingah ]h"]scanning and bss list handlingah$]h&]uh1hhhhhhhhKaubh)}(hhh](h)}(hUtility functionsh]hUtility functions}(hjadhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^dhhhhhKtubh)}(hAcfg80211 offers a number of utility functions that can be useful.h]hAcfg80211 offers a number of utility functions that can be useful.}(hjodhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:118: ./include/net/cfg80211.hhMhj^dhhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js+ieee80211_channel_to_frequency (C function) c.ieee80211_channel_to_frequencyhNtauh1jfhj^dhhhNhNubjx)}(hhh](j})}(hEint ieee80211_channel_to_frequency (int chan, enum nl80211_band band)h]j)}(hDint ieee80211_channel_to_frequency(int chan, enum nl80211_band band)h](j)}(hinth]hint}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMubj)}(h h]h }(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdhhhjdhMubj)}(hieee80211_channel_to_frequencyh]j)}(hieee80211_channel_to_frequencyh]hieee80211_channel_to_frequency}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdubah}(h]h ](jjeh"]h$]h&]jjuh1jhjdhhhjdhMubj)}(h"(int chan, enum nl80211_band band)h](j%)}(hint chanh](j)}(hinth]hint}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdubj)}(h h]h }(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdubj)}(hchanh]hchan}(hjdhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjdubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjdubj%)}(henum nl80211_band bandh](j)}(hjh]henum}(hj ehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubj)}(h h]h }(hjehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubh)}(hhh]j)}(h nl80211_bandh]h nl80211_band}(hj'ehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$eubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj)emodnameN classnameNj j )}j ]jf)}j^jdsb c.ieee80211_channel_to_frequencyasbuh1hhjeubj)}(h h]h }(hjGehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubj)}(hbandh]hband}(hjUehhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjeubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjdubeh}(h]h ]h"]h$]h&]jjuh1jhjdhhhjdhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjdhhhjdhMubah}(h]jdah ](jjeh"]h$]h&]jj)jhuh1j|hjdhMhjdhhubj)}(hhh]h)}(h#convert channel number to frequencyh]h#convert channel number to frequency}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj|ehhubah}(h]h ]h"]h$]h&]uh1jhjdhhhjdhMubeh}(h]h ](j8functioneh"]h$]h&]jj8jjejjejjjuh1jwhhhj^dhNhNubj)}(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)}(hjeh]h Parameters}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjeubj%)}(hhh](j*)}(h``int chan`` channel number h](j0)}(h ``int chan``h]j,)}(hjeh]hint chan}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjeubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjeubjJ)}(hhh]h)}(hchannel numberh]hchannel number}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehMhjeubah}(h]h ]h"]h$]h&]uh1jIhjeubeh}(h]h ]h"]h$]h&]uh1j)hjehMhjeubj*)}(hI``enum nl80211_band band`` band, necessary due to channel number overlap h](j0)}(h``enum nl80211_band band``h]j,)}(hjeh]henum nl80211_band band}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjeubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjeubjJ)}(hhh]h)}(h-band, necessary due to channel number overlaph]h-band, necessary due to channel number overlap}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjfubah}(h]h ]h"]h$]h&]uh1jIhjeubeh}(h]h ]h"]h$]h&]uh1j)hjfhMhjeubeh}(h]h ]h"]h$]h&]uh1j$hjeubh)}(h **Return**h]j)}(hj4fh]hReturn}(hj6fhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2fubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjeubh)}(hDThe corresponding frequency (in MHz), or 0 if the conversion failed.h]hDThe corresponding frequency (in MHz), or 0 if the conversion failed.}(hjJfhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjeubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^dhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js+ieee80211_frequency_to_channel (C function) c.ieee80211_frequency_to_channelhNtauh1jfhj^dhhhNhNubjx)}(hhh](j})}(h-int ieee80211_frequency_to_channel (int freq)h]j)}(h,int ieee80211_frequency_to_channel(int freq)h](j)}(hinth]hint}(hjyfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjufhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM#ubj)}(h h]h }(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjufhhhjfhM#ubj)}(hieee80211_frequency_to_channelh]j)}(hieee80211_frequency_to_channelh]hieee80211_frequency_to_channel}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfubah}(h]h ](jjeh"]h$]h&]jjuh1jhjufhhhjfhM#ubj)}(h (int freq)h]j%)}(hint freqh](j)}(hinth]hint}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfubj)}(h h]h }(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfubj)}(hfreqh]hfreq}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjfubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjfubah}(h]h ]h"]h$]h&]jjuh1jhjufhhhjfhM#ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjqfhhhjfhM#ubah}(h]jlfah ](jjeh"]h$]h&]jj)jhuh1j|hjfhM#hjnfhhubj)}(hhh]h)}(h#convert frequency to channel numberh]h#convert frequency to channel number}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM#hjfhhubah}(h]h ]h"]h$]h&]uh1jhjnfhhhjfhM#ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjgjjgjjjuh1jwhhhj^dhNhNubj)}(h}**Parameters** ``int freq`` center frequency in MHz **Return** The corresponding channel, or 0 if the conversion failed.h](h)}(h**Parameters**h]j)}(hjgh]h Parameters}(hj ghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM'hjgubj%)}(hhh]j*)}(h%``int freq`` center frequency in MHz h](j0)}(h ``int freq``h]j,)}(hj=gh]hint freq}(hj?ghhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj;gubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM$hj7gubjJ)}(hhh]h)}(hcenter frequency in MHzh]hcenter frequency in MHz}(hjVghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRghM$hjSgubah}(h]h ]h"]h$]h&]uh1jIhj7gubeh}(h]h ]h"]h$]h&]uh1j)hjRghM$hj4gubah}(h]h ]h"]h$]h&]uh1j$hjgubh)}(h **Return**h]j)}(hjxgh]hReturn}(hjzghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvgubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM&hjgubh)}(h9The corresponding channel, or 0 if the conversion failed.h]h9The corresponding channel, or 0 if the conversion failed.}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM%hjgubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^dhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js"ieee80211_get_channel (C function)c.ieee80211_get_channelhNtauh1jfhj^dhhhNhNubjx)}(hhh](j})}(hPstruct ieee80211_channel * ieee80211_get_channel (struct wiphy *wiphy, int freq)h]j)}(hNstruct ieee80211_channel *ieee80211_get_channel(struct wiphy *wiphy, int freq)h](j)}(hjh]hstruct}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjghhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM8ubj)}(h h]h }(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjghhhjghM8ubh)}(hhh]j)}(hieee80211_channelh]hieee80211_channel}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjgmodnameN classnameNj j )}j ]jf)}j^ieee80211_get_channelsbc.ieee80211_get_channelasbuh1hhjghhhjghM8ubj)}(h h]h }(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjghhhjghM8ubjz)}(hj}h]h*}(hj hhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjghhhjghM8ubj)}(hieee80211_get_channelh]j)}(hjgh]hieee80211_get_channel}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubah}(h]h ](jjeh"]h$]h&]jjuh1jhjghhhjghM8ubj)}(h(struct wiphy *wiphy, int freq)h](j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hj7hhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3hubj)}(h h]h }(hjDhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3hubh)}(hhh]j)}(hwiphyh]hwiphy}(hjUhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRhubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjWhmodnameN classnameNj j )}j ]jgc.ieee80211_get_channelasbuh1hhj3hubj)}(h h]h }(hjshhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3hubjz)}(hj}h]h*}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj3hubj)}(hwiphyh]hwiphy}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3hubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj/hubj%)}(hint freqh](j)}(hinth]hint}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubj)}(h h]h }(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubj)}(hfreqh]hfreq}(hjhhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj/hubeh}(h]h ]h"]h$]h&]jjuh1jhjghhhjghM8ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjghhhjghM8ubah}(h]jgah ](jjeh"]h$]h&]jj)jhuh1j|hjghM8hjghhubj)}(hhh]h)}(h5get channel struct from wiphy for specified frequencyh]h5get channel struct from wiphy for specified frequency}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM8hjhhhubah}(h]h ]h"]h$]h&]uh1jhjghhhjghM8ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjijjijjjuh1jwhhhj^dhNhNubj)}(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)}(hjih]h Parameters}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhj iubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM<hj iubj%)}(hhh](j*)}(h@``struct wiphy *wiphy`` the struct wiphy to get the channel for h](j0)}(h``struct wiphy *wiphy``h]j,)}(hj.ih]hstruct wiphy *wiphy}(hj0ihhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj,iubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM:hj(iubjJ)}(hhh]h)}(h'the struct wiphy to get the channel forh]h'the struct wiphy to get the channel for}(hjGihhhNhNubah}(h]h ]h"]h$]h&]uh1hhjCihM:hjDiubah}(h]h ]h"]h$]h&]uh1jIhj(iubeh}(h]h ]h"]h$]h&]uh1j)hjCihM:hj%iubj*)}(h:``int freq`` the center frequency (in MHz) of the channel h](j0)}(h ``int freq``h]j,)}(hjgih]hint freq}(hjiihhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjeiubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM;hjaiubjJ)}(hhh]h)}(h,the center frequency (in MHz) of the channelh]h,the center frequency (in MHz) of the channel}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|ihM;hj}iubah}(h]h ]h"]h$]h&]uh1jIhjaiubeh}(h]h ]h"]h$]h&]uh1j)hj|ihM;hj%iubeh}(h]h ]h"]h$]h&]uh1j$hj iubh)}(h **Return**h]j)}(hjih]hReturn}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM=hj iubh)}(h.The channel struct from **wiphy** at **freq**.h](hThe channel struct from }(hjihhhNhNubj)}(h **wiphy**h]hwiphy}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubh at }(hjihhhNhNubj)}(h**freq**h]hfreq}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubh.}(hjihhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM<hj iubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^dhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js(ieee80211_get_response_rate (C function)c.ieee80211_get_response_ratehNtauh1jfhj^dhhhNhNubjx)}(hhh](j})}(hconst struct ieee80211_rate * ieee80211_get_response_rate (struct ieee80211_supported_band *sband, u32 basic_rates, int bitrate)h]j)}(h~const struct ieee80211_rate *ieee80211_get_response_rate(struct ieee80211_supported_band *sband, u32 basic_rates, int bitrate)h](j)}(hjIh]hconst}(hj jhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMyubj)}(h h]h }(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjhhhjjhMyubj)}(hjh]hstruct}(hj'jhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjhhhjjhMyubj)}(h h]h }(hj4jhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjhhhjjhMyubh)}(hhh]j)}(hieee80211_rateh]hieee80211_rate}(hjEjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjGjmodnameN classnameNj j )}j ]jf)}j^ieee80211_get_response_ratesbc.ieee80211_get_response_rateasbuh1hhjjhhhjjhMyubj)}(h h]h }(hjfjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjhhhjjhMyubjz)}(hj}h]h*}(hjtjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjjhhhjjhMyubj)}(hieee80211_get_response_rateh]j)}(hjcjh]hieee80211_get_response_rate}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjjhhhjjhMyubj)}(hF(struct ieee80211_supported_band *sband, u32 basic_rates, int bitrate)h](j%)}(h&struct ieee80211_supported_band *sbandh](j)}(hjh]hstruct}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjubj)}(h h]h }(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjubh)}(hhh]j)}(hieee80211_supported_bandh]hieee80211_supported_band}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjjmodnameN classnameNj j )}j ]jajc.ieee80211_get_response_rateasbuh1hhjjubj)}(h h]h }(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjubjz)}(hj}h]h*}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjjubj)}(hsbandh]hsband}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjjubj%)}(hu32 basic_ratesh](h)}(hhh]j)}(hu32h]hu32}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjkmodnameN classnameNj j )}j ]jajc.ieee80211_get_response_rateasbuh1hhj kubj)}(h h]h }(hj1khhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj kubj)}(h basic_ratesh]h basic_rates}(hj?khhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj kubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjjubj%)}(h int bitrateh](j)}(hinth]hint}(hjXkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjTkubj)}(h h]h }(hjfkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjTkubj)}(hbitrateh]hbitrate}(hjtkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjTkubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjjubeh}(h]h ]h"]h$]h&]jjuh1jhjjhhhjjhMyubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjjhhhjjhMyubah}(h]jiah ](jjeh"]h$]h&]jj)jhuh1j|hjjhMyhjjhhubj)}(hhh]h)}(hget basic rate for a given rateh]hget basic rate for a given rate}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMyhjkhhubah}(h]h ]h"]h$]h&]uh1jhjjhhhjjhMyubeh}(h]h ](j8functioneh"]h$]h&]jj8jjkjjkjjjuh1jwhhhj^dhNhNubj)}(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)}(hjkh]h Parameters}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM}hjkubj%)}(hhh](j*)}(hI``struct ieee80211_supported_band *sband`` the band to look for rates in h](j0)}(h*``struct ieee80211_supported_band *sband``h]j,)}(hjkh]h&struct ieee80211_supported_band *sband}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjkubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM{hjkubjJ)}(hhh]h)}(hthe band to look for rates inh]hthe band to look for rates in}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhM{hjkubah}(h]h ]h"]h$]h&]uh1jIhjkubeh}(h]h ]h"]h$]h&]uh1j)hjkhM{hjkubj*)}(h*``u32 basic_rates`` bitmap of basic rates h](j0)}(h``u32 basic_rates``h]j,)}(hjlh]hu32 basic_rates}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjlubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM|hjlubjJ)}(hhh]h)}(hbitmap of basic ratesh]hbitmap of basic rates}(hj1lhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-lhM|hj.lubah}(h]h ]h"]h$]h&]uh1jIhjlubeh}(h]h ]h"]h$]h&]uh1j)hj-lhM|hjkubj*)}(h=``int bitrate`` the bitrate for which to find the basic rate h](j0)}(h``int bitrate``h]j,)}(hjQlh]h int bitrate}(hjSlhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjOlubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhM}hjKlubjJ)}(hhh]h)}(h,the bitrate for which to find the basic rateh]h,the bitrate for which to find the basic rate}(hjjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjflhM}hjglubah}(h]h ]h"]h$]h&]uh1jIhjKlubeh}(h]h ]h"]h$]h&]uh1j)hjflhM}hjkubeh}(h]h ]h"]h$]h&]uh1j$hjkubh)}(h **Return**h]j)}(hjlh]hReturn}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjkubh)}(hThe 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]hThe 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.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjkubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj^dhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js&ieee80211_radiotap_iterator (C struct)c.ieee80211_radiotap_iteratorhNtauh1jfhj^dhhhNhNubjx)}(hhh](j})}(hieee80211_radiotap_iteratorh]j)}(h"struct ieee80211_radiotap_iteratorh](j)}(hjh]hstruct}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMubj)}(h h]h }(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlhhhjlhMubj)}(hieee80211_radiotap_iteratorh]j)}(hjlh]hieee80211_radiotap_iterator}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlubah}(h]h ](jjeh"]h$]h&]jjuh1jhjlhhhjlhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjlhhhjlhMubah}(h]jlah ](jjeh"]h$]h&]jj)jhuh1j|hjlhMhjlhhubj)}(hhh]h)}(h&tracks walk thru present radiotap argsh]h&tracks walk thru present radiotap args}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjmhhubah}(h]h ]h"]h$]h&]uh1jhjlhhhjlhMubeh}(h]h ](j8structeh"]h$]h&]jj8jj+mjj+mjjjuh1jwhhhj^dhNhNubj)}(hX**Definition**:: struct ieee80211_radiotap_iterator { struct ieee80211_radiotap_header *_rtheader; const struct ieee80211_radiotap_vendor_namespaces *_vns; const struct ieee80211_radiotap_namespace *current_namespace; unsigned char *_arg, *_next_ns_data; __le32 *_next_bitmap; unsigned char *this_arg; int this_arg_index; int this_arg_size; int is_radiotap_ns; int _max_length; int _arg_index; uint32_t _bitmap_shifter; int _reset_on_ext; }; **Members** ``_rtheader`` pointer to the radiotap header we are walking through ``_vns`` vendor namespace definitions ``current_namespace`` pointer to the current namespace definition (or internally ``NULL`` if the current namespace is unknown) ``_arg`` next argument pointer ``_next_ns_data`` beginning of the next namespace's data ``_next_bitmap`` internal pointer to next present u32 ``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 ``this_arg_index`` index of current arg, valid after each successful call to ieee80211_radiotap_iterator_next() ``this_arg_size`` length of the current arg, for convenience ``is_radiotap_ns`` indicates whether the current namespace is the default radiotap namespace or not ``_max_length`` length of radiotap header in cpu byte ordering ``_arg_index`` next argument index ``_bitmap_shifter`` internal shifter for curr u32 bitmap, b0 set == arg present ``_reset_on_ext`` internal; reset the arg index to 0 when going to the next bitmap wordh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj7mhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3mubh:}(hj3mhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj/mubj: )}(hXstruct ieee80211_radiotap_iterator { struct ieee80211_radiotap_header *_rtheader; const struct ieee80211_radiotap_vendor_namespaces *_vns; const struct ieee80211_radiotap_namespace *current_namespace; unsigned char *_arg, *_next_ns_data; __le32 *_next_bitmap; unsigned char *this_arg; int this_arg_index; int this_arg_size; int is_radiotap_ns; int _max_length; int _arg_index; uint32_t _bitmap_shifter; int _reset_on_ext; };h]hXstruct ieee80211_radiotap_iterator { struct ieee80211_radiotap_header *_rtheader; const struct ieee80211_radiotap_vendor_namespaces *_vns; const struct ieee80211_radiotap_namespace *current_namespace; unsigned char *_arg, *_next_ns_data; __le32 *_next_bitmap; unsigned char *this_arg; int this_arg_index; int this_arg_size; int is_radiotap_ns; int _max_length; int _arg_index; uint32_t _bitmap_shifter; int _reset_on_ext; };}hjPmsbah}(h]h ]h"]h$]h&]jjuh1j9 ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj/mubh)}(h **Members**h]j)}(hjamh]hMembers}(hjcmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_mubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhj/mubj%)}(hhh](j*)}(hD``_rtheader`` pointer to the radiotap header we are walking through h](j0)}(h ``_rtheader``h]j,)}(hjmh]h _rtheader}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj~mubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjzmubjJ)}(hhh]h)}(h5pointer to the radiotap header we are walking throughh]h5pointer to the radiotap header we are walking through}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhMhjmubah}(h]h ]h"]h$]h&]uh1jIhjzmubeh}(h]h ]h"]h$]h&]uh1j)hjmhMhjwmubj*)}(h&``_vns`` vendor namespace definitions h](j0)}(h``_vns``h]j,)}(hjmh]h_vns}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjmubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjmubjJ)}(hhh]h)}(hvendor namespace definitionsh]hvendor namespace definitions}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhMhjmubah}(h]h ]h"]h$]h&]uh1jIhjmubeh}(h]h ]h"]h$]h&]uh1j)hjmhMhjwmubj*)}(h``current_namespace`` pointer to the current namespace definition (or internally ``NULL`` if the current namespace is unknown) h](j0)}(h``current_namespace``h]j,)}(hjmh]hcurrent_namespace}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjmubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjmubjJ)}(hhh]h)}(hhpointer to the current namespace definition (or internally ``NULL`` if the current namespace is unknown)h](h;pointer to the current namespace definition (or internally }(hj nhhhNhNubj,)}(h``NULL``h]hNULL}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj nubh% if the current namespace is unknown)}(hj nhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:121: ./include/net/cfg80211.hhMhjnubah}(h]h ]h"]h$]h&]uh1jIhjmubeh}(h]h ]h"]h$]h&]uh1j)hjnhMhjwmubj*)}(h``_arg`` next argument pointer h](j0)}(h``_arg``h]j,)}(hj>nh]h_arg}(hj@nhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjthhhhhKubh)}(hIn addition to generic utilities, cfg80211 also offers functions that help implement the data path for devices that do not do the 802.11/802.3 conversion on the device.h]hIn addition to generic utilities, cfg80211 also offers functions that help implement the data path for devices that do not do the 802.11/802.3 conversion on the device.}(hjOthhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:134: ./include/net/cfg80211.hhMhj>thhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js#ieee80211_data_to_8023 (C function)c.ieee80211_data_to_8023hNtauh1jfhj>thhhNhNubjx)}(hhh](j})}(h\int ieee80211_data_to_8023 (struct sk_buff *skb, const u8 *addr, enum nl80211_iftype iftype)h]j)}(h[int ieee80211_data_to_8023(struct sk_buff *skb, const u8 *addr, enum nl80211_iftype iftype)h](j)}(hinth]hint}(hjwthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjsthhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMubj)}(h h]h }(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjsthhhjthMubj)}(hieee80211_data_to_8023h]j)}(hieee80211_data_to_8023h]hieee80211_data_to_8023}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjtubah}(h]h ](jjeh"]h$]h&]jjuh1jhjsthhhjthMubj)}(hA(struct sk_buff *skb, const u8 *addr, enum nl80211_iftype iftype)h](j%)}(hstruct sk_buff *skbh](j)}(hjh]hstruct}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjtubj)}(h h]h }(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjtubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjtmodnameN classnameNj j )}j ]jf)}j^jtsbc.ieee80211_data_to_8023asbuh1hhjtubj)}(h h]h }(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjtubjz)}(hj}h]h*}(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjtubj)}(hskbh]hskb}(hj uhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjtubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjtubj%)}(hconst u8 *addrh](j)}(hjIh]hconst}(hj&uhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"uubj)}(h h]h }(hj3uhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"uubh)}(hhh]j)}(hu8h]hu8}(hjDuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAuubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjFumodnameN classnameNj j )}j ]jtc.ieee80211_data_to_8023asbuh1hhj"uubj)}(h h]h }(hjbuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"uubjz)}(hj}h]h*}(hjpuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj"uubj)}(haddrh]haddr}(hj}uhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"uubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjtubj%)}(henum nl80211_iftype iftypeh](j)}(hjh]henum}(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubj)}(h h]h }(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubh)}(hhh]j)}(hnl80211_iftypeh]hnl80211_iftype}(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjumodnameN classnameNj j )}j ]jtc.ieee80211_data_to_8023asbuh1hhjuubj)}(h h]h }(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubj)}(hiftypeh]hiftype}(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjtubeh}(h]h ]h"]h$]h&]jjuh1jhjsthhhjthMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjothhhjthMubah}(h]jjtah ](jjeh"]h$]h&]jj)jhuh1j|hjthMhjlthhubj)}(hhh]h)}(h%convert an 802.11 data frame to 802.3h]h%convert an 802.11 data frame to 802.3}(hj vhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjvhhubah}(h]h ]h"]h$]h&]uh1jhjlthhhjthMubeh}(h]h ](j8functioneh"]h$]h&]jj8jj"vjj"vjjjuh1jwhhhj>thNhNubj)}(h**Parameters** ``struct sk_buff *skb`` the 802.11 data frame ``const u8 *addr`` the device MAC address ``enum nl80211_iftype iftype`` the virtual interface type **Return** 0 on success. Non-zero on error.h](h)}(h**Parameters**h]j)}(hj,vh]h Parameters}(hj.vhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*vubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM hj&vubj%)}(hhh](j*)}(h.``struct sk_buff *skb`` the 802.11 data frame h](j0)}(h``struct sk_buff *skb``h]j,)}(hjKvh]hstruct sk_buff *skb}(hjMvhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjIvubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjEvubjJ)}(hhh]h)}(hthe 802.11 data frameh]hthe 802.11 data frame}(hjdvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`vhMhjavubah}(h]h ]h"]h$]h&]uh1jIhjEvubeh}(h]h ]h"]h$]h&]uh1j)hj`vhMhjBvubj*)}(h*``const u8 *addr`` the device MAC address h](j0)}(h``const u8 *addr``h]j,)}(hjvh]hconst u8 *addr}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjvubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhj~vubjJ)}(hhh]h)}(hthe device MAC addressh]hthe device MAC address}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhMhjvubah}(h]h ]h"]h$]h&]uh1jIhj~vubeh}(h]h ]h"]h$]h&]uh1j)hjvhMhjBvubj*)}(h:``enum nl80211_iftype iftype`` the virtual interface type h](j0)}(h``enum nl80211_iftype iftype``h]j,)}(hjvh]henum nl80211_iftype iftype}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjvubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMhjvubjJ)}(hhh]h)}(hthe virtual interface typeh]hthe virtual interface type}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhMhjvubah}(h]h ]h"]h$]h&]uh1jIhjvubeh}(h]h ]h"]h$]h&]uh1j)hjvhMhjBvubeh}(h]h ]h"]h$]h&]uh1j$hj&vubh)}(h **Return**h]j)}(hjvh]hReturn}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM!hj&vubh)}(h 0 on success. Non-zero on error.h]h 0 on success. Non-zero on error.}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM hj&vubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj>thhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js%ieee80211_amsdu_to_8023s (C function)c.ieee80211_amsdu_to_8023shNtauh1jfhj>thhhNhNubjx)}(hhh](j})}(hvoid ieee80211_amsdu_to_8023s (struct sk_buff *skb, struct sk_buff_head *list, const u8 *addr, enum nl80211_iftype iftype, const unsigned int extra_headroom, const u8 *check_da, const u8 *check_sa, u8 mesh_control)h]j)}(hvoid ieee80211_amsdu_to_8023s(struct sk_buff *skb, struct sk_buff_head *list, const u8 *addr, enum nl80211_iftype iftype, const unsigned int extra_headroom, const u8 *check_da, const u8 *check_sa, u8 mesh_control)h](j)}(hvoidh]hvoid}(hj=whhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj9whhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM9ubj)}(h h]h }(hjLwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj9whhhjKwhM9ubj)}(hieee80211_amsdu_to_8023sh]j)}(hieee80211_amsdu_to_8023sh]hieee80211_amsdu_to_8023s}(hj^whhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZwubah}(h]h ](jjeh"]h$]h&]jjuh1jhj9whhhjKwhM9ubj)}(h(struct sk_buff *skb, struct sk_buff_head *list, const u8 *addr, enum nl80211_iftype iftype, const unsigned int extra_headroom, const u8 *check_da, const u8 *check_sa, u8 mesh_control)h](j%)}(hstruct sk_buff *skbh](j)}(hjh]hstruct}(hjzwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvwubj)}(h h]h }(hjwhhhNhNubahe}(h]h ]jah"]h$]h&]uh1jhjvwubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjwmodnameN classnameNj j )}j ]jf)}j^j`wsbc.ieee80211_amsdu_to_8023sasbuh1hhjvwubj)}(h h]h }(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvwubjz)}(hj}h]h*}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjvwubj)}(hskbh]hskb}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvwubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjrwubj%)}(hstruct sk_buff_head *listh](j)}(hjh]hstruct}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubj)}(h h]h }(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubh)}(hhh]j)}(h sk_buff_headh]h sk_buff_head}(hj xhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj xmodnameN classnameNj j )}j ]jwc.ieee80211_amsdu_to_8023sasbuh1hhjwubj)}(h h]h }(hj(xhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubjz)}(hj}h]h*}(hj6xhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjwubj)}(hlisth]hlist}(hjCxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjrwubj%)}(hconst u8 *addrh](j)}(hjIh]hconst}(hj\xhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXxubj)}(h h]h }(hjixhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXxubh)}(hhh]j)}(hu8h]hu8}(hjzxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwxubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj|xmodnameN classnameNj j )}j ]jwc.ieee80211_amsdu_to_8023sasbuh1hhjXxubj)}(h h]h }(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXxubjz)}(hj}h]h*}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjXxubj)}(haddrh]haddr}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXxubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjrwubj%)}(henum nl80211_iftype iftypeh](j)}(hjh]henum}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubj)}(h h]h }(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubh)}(hhh]j)}(hnl80211_iftypeh]hnl80211_iftype}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjxmodnameN classnameNj j )}j ]jwc.ieee80211_amsdu_to_8023sasbuh1hhjxubj)}(h h]h }(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubj)}(hiftypeh]hiftype}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjrwubj%)}(h!const unsigned int extra_headroomh](j)}(hjIh]hconst}(hj/yhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+yubj)}(h h]h }(hjthNhNubj)}(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)}(hjzh]h Parameters}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM=hjzubj%)}(hhh](j*)}(hD``struct sk_buff *skb`` The input A-MSDU frame without any headers. h](j0)}(h``struct sk_buff *skb``h]j,)}(hj{h]hstruct sk_buff *skb}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj{ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM?hj{ubjJ)}(hhh]h)}(h+The input A-MSDU frame without any headers.h]h+The input A-MSDU frame without any headers.}(hj.{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*{hM?hj+{ubah}(h]h ]h"]h$]h&]uh1jIhj{ubeh}(h]h ]h"]h$]h&]uh1j)hj*{hM?hj {ubj*)}(hs``struct sk_buff_head *list`` The output list of 802.3 frames. It must be allocated and initialized by the caller. h](j0)}(h``struct sk_buff_head *list``h]j,)}(hjN{h]hstruct sk_buff_head *list}(hjP{hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjL{ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMAhjH{ubjJ)}(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.}(hjg{hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM@hjd{ubah}(h]h ]h"]h$]h&]uh1jIhjH{ubeh}(h]h ]h"]h$]h&]uh1j)hjc{hMAhj {ubj*)}(h+``const u8 *addr`` The device MAC address. h](j0)}(h``const u8 *addr``h]j,)}(hj{h]hconst u8 *addr}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj{ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMBhj{ubjJ)}(hhh]h)}(hThe device MAC address.h]hThe device MAC address.}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hMBhj{ubah}(h]h ]h"]h$]h&]uh1jIhj{ubeh}(h]h ]h"]h$]h&]uh1j)hj{hMBhj {ubj*)}(h:``enum nl80211_iftype iftype`` The device interface type. h](j0)}(h``enum nl80211_iftype iftype``h]j,)}(hj{h]henum nl80211_iftype iftype}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj{ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMChj{ubjJ)}(hhh]h)}(hThe device interface type.h]hThe device interface type.}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hMChj{ubah}(h]h ]h"]h$]h&]uh1jIhj{ubeh}(h]h ]h"]h$]h&]uh1j)hj{hMChj {ubj*)}(h\``const unsigned int extra_headroom`` The hardware extra headroom for SKBs in the **list**. h](j0)}(h%``const unsigned int extra_headroom``h]j,)}(hj{h]h!const unsigned int extra_headroom}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj{ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMDhj{ubjJ)}(hhh]h)}(h5The hardware extra headroom for SKBs in the **list**.h](h,The hardware extra headroom for SKBs in the }(hj|hhhNhNubj)}(h**list**h]hlist}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubh.}(hj|hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj|hMDhj|ubah}(h]h ]h"]h$]h&]uh1jIhj{ubeh}(h]h ]h"]h$]h&]uh1j)hj|hMDhj {ubj*)}(hI``const u8 *check_da`` DA to check in the inner ethernet header, or NULL h](j0)}(h``const u8 *check_da``h]j,)}(hjE|h]hconst u8 *check_da}(hjG|hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjC|ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMEhj?|ubjJ)}(hhh]h)}(h1DA to check in the inner ethernet header, or NULLh]h1DA to check in the inner ethernet header, or NULL}(hj^|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZ|hMEhj[|ubah}(h]h ]h"]h$]h&]uh1jIhj?|ubeh}(h]h ]h"]h$]h&]uh1j)hjZ|hMEhj {ubj*)}(hI``const u8 *check_sa`` SA to check in the inner ethernet header, or NULL h](j0)}(h``const u8 *check_sa``h]j,)}(hj~|h]hconst u8 *check_sa}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj||ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMFhjx|ubjJ)}(hhh]h)}(h1SA to check in the inner ethernet header, or NULLh]h1SA to check in the inner ethernet header, or NULL}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMFhj|ubah}(h]h ]h"]h$]h&]uh1jIhjx|ubeh}(h]h ]h"]h$]h&]uh1j)hj|hMFhj {ubj*)}(h=``u8 mesh_control`` see mesh_hdr in ieee80211_is_valid_amsdu h](j0)}(h``u8 mesh_control``h]j,)}(hj|h]hu8 mesh_control}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj|ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMGhj|ubjJ)}(hhh]h)}(h(see mesh_hdr in ieee80211_is_valid_amsduh]h(see mesh_hdr in ieee80211_is_valid_amsdu}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMGhj|ubah}(h]h ]h"]h$]h&]uh1jIhj|ubeh}(h]h ]h"]h$]h&]uh1j)hj|hMGhj {ubeh}(h]h ]h"]h$]h&]uh1j$hjzubh)}(h**Description**h]j)}(hj|h]h Description}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMIhjzubh)}(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}hhhNhNubj)}(h**list**h]hlist}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubh( will be empty if the decode fails. The }(hj}hhhNhNubj)}(h**skb**h]hskb}(hj"}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubhU must be fully header-less before being passed in here; it is freed in this function.}(hj}hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhM:hjzubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj>thhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js#cfg80211_classify8021d (C function)c.cfg80211_classify8021dhNtauh1jfhj>thhhNhNubjx)}(hhh](j})}(h[unsigned int cfg80211_classify8021d (struct sk_buff *skb, struct cfg80211_qos_map *qos_map)h]j)}(hZunsigned int cfg80211_classify8021d(struct sk_buff *skb, struct cfg80211_qos_map *qos_map)h](j)}(hunsignedh]hunsigned}(hj[}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjW}hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMiubj)}(h h]h }(hjj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjW}hhhji}hMiubj)}(hinth]hint}(hjx}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjW}hhhji}hMiubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjW}hhhji}hMiubj)}(hcfg80211_classify8021dh]j)}(hcfg80211_classify8021dh]hcfg80211_classify8021d}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubah}(h]h ](jjeh"]h$]h&]jjuh1jhjW}hhhji}hMiubj)}(h7(struct sk_buff *skb, struct cfg80211_qos_map *qos_map)h](j%)}(hstruct sk_buff *skbh](j)}(hjh]hstruct}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj}modnameN classnameNj j )}j ]jf)}j^j}sbc.cfg80211_classify8021dasbuh1hhj}ubj)}(h h]h }(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubjz)}(hj}h]h*}(hj~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj}ubj)}(hskbh]hskb}(hj ~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj}ubj%)}(h struct cfg80211_qos_map *qos_maph](j)}(hjh]hstruct}(hj&~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"~ubj)}(h h]h }(hj3~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"~ubh)}(hhh]j)}(hcfg80211_qos_maph]hcfg80211_qos_map}(hjD~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjA~ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjF~modnameN classnameNj j )}j ]j}c.cfg80211_classify8021dasbuh1hhj"~ubj)}(h h]h }(hjb~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"~ubjz)}(hj}h]h*}(hjp~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj"~ubj)}(hqos_maph]hqos_map}(hj}~hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"~ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj}ubeh}(h]h ]h"]h$]h&]jjuh1jhjW}hhhji}hMiubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjS}hhhji}hMiubah}(h]jN}ah ](jjeh"]h$]h&]jj)jhuh1j|hji}hMihjP}hhubj)}(hhh]h)}(h,determine the 802.1p/1d tag for a data frameh]h,determine the 802.1p/1d tag for a data frame}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMihj~hhubah}(h]h ]h"]h$]h&]uh1jhjP}hhhji}hMiubeh}(h]h ](j8functioneh"]h$]h&]jj8jj~jj~jjjuh1jwhhhj>thNhNubj)}(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)}(hj~h]h Parameters}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMmhj~ubj%)}(hhh](j*)}(h'``struct sk_buff *skb`` the data frame h](j0)}(h``struct sk_buff *skb``h]j,)}(hj~h]hstruct sk_buff *skb}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj~ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMjhj~ubjJ)}(hhh]h)}(hthe data frameh]hthe data frame}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~hMjhj~ubah}(h]h ]h"]h$]h&]uh1jIhj~ubeh}(h]h ]h"]h$]h&]uh1j)hj~hMjhj~ubj*)}(hX``struct cfg80211_qos_map *qos_map`` Interworking QoS mapping or ``NULL`` if not in use h](j0)}(h$``struct cfg80211_qos_map *qos_map``h]j,)}(hj!h]h struct cfg80211_qos_map *qos_map}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMkhjubjJ)}(hhh]h)}(h2Interworking QoS mapping or ``NULL`` if not in useh](hInterworking QoS mapping or }(hj:hhhNhNubj,)}(h``NULL``h]hNULL}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj:ubh if not in use}(hj:hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj6hMkhj7ubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hj6hMkhj~ubeh}(h]h ]h"]h$]h&]uh1j$hj~ubh)}(h **Return**h]j)}(hjnh]hReturn}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMmhj~ubh)}(hThe 802.1p/1d tag.h]hThe 802.1p/1d tag.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:137: ./include/net/cfg80211.hhMlhj~ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj>thhhNhNubeh}(h]data-path-helpersah ]h"]data path helpersah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(h%Regulatory enforcement infrastructureh]h%Regulatory enforcement infrastructure}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh)}(hTODOh]hTODO}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:146: ./include/net/cfg80211.hhMvhjhhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsregulatory_hint (C function)c.regulatory_hinthNtauh1jfhjhhhNhNubjx)}(hhh](j})}(h=int regulatory_hint (struct wiphy *wiphy, const char *alpha2)h]j)}(halpha2 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)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubj%)}(hhh](j*)}(h```struct wiphy *wiphy`` the wireless device giving the hint (used only for reporting conflicts) h](j0)}(h``struct wiphy *wiphy``h]j,)}(hj9h]hstruct wiphy *wiphy}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj7ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhM~hj3ubjJ)}(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)}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhM}hjOubah}(h]h ]h"]h$]h&]uh1jIhj3ubeh}(h]h ]h"]h$]h&]uh1j)hjNhM~hj0ubj*)}(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](j0)}(h``const char *alpha2``h]j,)}(hjsh]hconst char *alpha2}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjqubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjmubjJ)}(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 }(hjhhhNhNubj)}(h**rd**h]hrd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhw is set this should be NULL. Note that if you set this to NULL you should still set rd->alpha2 to some accepted alpha2.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubah}(h]h ]h"]h$]h&]uh1jIhjmubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj0ubeh}(h]h ]h"]h$]h&]uh1j$hjubh)}(h**Description**h]j)}(hjh]h Description}(hjÁhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubh)}(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.hhMhjubh)}(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().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubh)}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubh)}(h0 on success. -ENOMEM.h]h0 on success. -ENOMEM.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js*wiphy_apply_custom_regulatory (C function)c.wiphy_apply_custom_regulatoryhNtauh1jfhjhhhNhNubjx)}(hhh](j})}(h`void wiphy_apply_custom_regulatory (struct wiphy *wiphy, const struct ieee80211_regdomain *regd)h]j)}(h_void wiphy_apply_custom_regulatory(struct wiphy *wiphy, const struct ieee80211_regdomain *regd)h](j)}(hvoidh]hvoid}(hjKhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMubj)}(h h]h }(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjGhhhjYhMubj)}(hwiphy_apply_custom_regulatoryh]j)}(hwiphy_apply_custom_regulatoryh]hwiphy_apply_custom_regulatory}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhubah}(h]h ](jjeh"]h$]h&]jjuh1jhjGhhhjYhMubj)}(h=(struct wiphy *wiphy, const struct ieee80211_regdomain *regd)h](j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jf)}j^jnsbc.wiphy_apply_custom_regulatoryasbuh1hhjubj)}(h h]h }(hjƂhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjԂhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h&const struct ieee80211_regdomain *regdh](j)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hieee80211_regdomainh]hieee80211_regdomain}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj5modnameN classnameNj j )}j ]j‚c.wiphy_apply_custom_regulatoryasbuh1hhjubj)}(h h]h }(hjQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hregdh]hregd}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubeh}(h]h ]h"]h$]h&]jjuh1jhjGhhhjYhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjChhhjYhMubah}(h]j>ah ](jjeh"]h$]h&]jj)jhuh1j|hjYhMhj@hhubj)}(hhh]h)}(h'apply a custom driver regulatory domainh]h'apply a custom driver regulatory domain}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhj@hhhjYhMubeh}(h]h ](j8functioneh"]h$]h&]jj8jjjjjjjuh1jwhhhjhNhNubj)}(hX**Parameters** ``struct wiphy *wiphy`` the wireless device we want to process the regulatory domain on ``const struct ieee80211_regdomain *regd`` the custom regulatory domain to use for this wiphy **Description** Drivers can sometimes have custom regulatory domains which do not apply to a specific country. Drivers can use this to apply such custom regulatory domains. This routine must be called prior to wiphy registration. The custom regulatory domain will be trusted completely and as such previous default channel settings will be disregarded. If no rule is found for a channel on the regulatory domain the channel will be disabled. Drivers using this for a wiphy should also set the wiphy flag REGULATORY_CUSTOM_REG or cfg80211 will set it for the wiphy that called this helper.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubj%)}(hhh](j*)}(hX``struct wiphy *wiphy`` the wireless device we want to process the regulatory domain on h](j0)}(h``struct wiphy *wiphy``h]j,)}(hj׃h]hstruct wiphy *wiphy}(hjكhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjՃubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjуubjJ)}(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&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jIhjуubeh}(h]h ]h"]h$]h&]uh1j)hjhMhj΃ubj*)}(h^``const struct ieee80211_regdomain *regd`` the custom regulatory domain to use for this wiphy h](j0)}(h*``const struct ieee80211_regdomain *regd``h]j,)}(hjh]h&const struct ieee80211_regdomain *regd}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj ubjJ)}(hhh]h)}(h2the custom regulatory domain to use for this wiphyh]h2the custom regulatory domain to use for this wiphy}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hMhj&ubah}(h]h ]h"]h$]h&]uh1jIhj ubeh}(h]h ]h"]h$]h&]uh1j)hj%hMhj΃ubeh}(h]h ]h"]h$]h&]uh1j$hjubh)}(h**Description**h]j)}(hjKh]h Description}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubh)}(hX<Drivers can sometimes have custom regulatory domains which do not apply to a specific country. Drivers can use this to apply such custom regulatory domains. This routine must be called prior to wiphy registration. The custom regulatory domain will be trusted completely and as such previous default channel settings will be disregarded. If no rule is found for a channel on the regulatory domain the channel will be disabled. Drivers using this for a wiphy should also set the wiphy flag REGULATORY_CUSTOM_REG or cfg80211 will set it for the wiphy that called this helper.h]hX<Drivers can sometimes have custom regulatory domains which do not apply to a specific country. Drivers can use this to apply such custom regulatory domains. This routine must be called prior to wiphy registration. The custom regulatory domain will be trusted completely and as such previous default channel settings will be disregarded. If no rule is found for a channel on the regulatory domain the channel will be disabled. Drivers using this for a wiphy should also set the wiphy flag REGULATORY_CUSTOM_REG or cfg80211 will set it for the wiphy that called this helper.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](jsfreq_reg_info (C function)c.freq_reg_infohNtauh1jfhjhhhNhNubjx)}(hhh](j})}(hVconst struct ieee80211_reg_rule * freq_reg_info (struct wiphy *wiphy, u32 center_freq)h]j)}(hTconst struct ieee80211_reg_rule *freq_reg_info(struct wiphy *wiphy, u32 center_freq)h](j)}(hjIh]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubh)}(hhh]j)}(hieee80211_reg_ruleh]hieee80211_reg_rule}(hjʄhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDŽubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj̄modnameN classnameNj j )}j ]jf)}j^ freq_reg_infosbc.freq_reg_infoasbuh1hhjhhhjhMubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjhhhjhMubj)}(h freq_reg_infoh]j)}(hjh]h freq_reg_info}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhMubj)}(h&(struct wiphy *wiphy, u32 center_freq)h](j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubj)}(h h]h }(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubh)}(hhh]j)}(hwiphyh]hwiphy}(hjChhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjEmodnameN classnameNj j )}j ]jc.freq_reg_infoasbuh1hhj!ubj)}(h h]h }(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubjz)}(hj}h]h*}(hjohhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj!ubj)}(hwiphyh]hwiphy}(hj|hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj!ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(hu32 center_freqh](h)}(hhh]j)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jc.freq_reg_infoasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h center_freqh]h center_freq}(hjąhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhMhjhhubj)}(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.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](j8functioneh"]h$]h&]jj8jjjjjjjuh1jwhhhjhNhNubj)}(hX**Parameters** ``struct wiphy *wiphy`` the wiphy for which we want to process this rule for ``u32 center_freq`` Frequency in KHz for which we want regulatory information for **Description** Use this function to get the regulatory rule for a specific frequency on a given wireless device. If the device has a specific regulatory domain it wants to follow we respect that unless a country IE has been received and processed already. **Return** A valid pointer, or, when an error occurs, for example if no rule can be found, the return value is encoded using ERR_PTR(). Use IS_ERR() to check and PTR_ERR() to obtain the numeric return value. The numeric return value will be -ERANGE if we determine the given center_freq does not even have a regulatory rule for a frequency range in the center_freq's band. See freq_in_rule_band() for our current definition of a band -- this is purely subjective and right now it's 802.11 specific.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj ubj%)}(hhh](j*)}(hM``struct wiphy *wiphy`` the wiphy for which we want to process this rule for h](j0)}(h``struct wiphy *wiphy``h]j,)}(hj/h]hstruct wiphy *wiphy}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj-ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj)ubjJ)}(hhh]h)}(h4the wiphy for which we want to process this rule forh]h4the wiphy for which we want to process this rule for}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDhMhjEubah}(h]h ]h"]h$]h&]uh1jIhj)ubeh}(h]h ]h"]h$]h&]uh1j)hjDhMhj&ubj*)}(hR``u32 center_freq`` Frequency in KHz for which we want regulatory information for h](j0)}(h``u32 center_freq``h]j,)}(hjhh]hu32 center_freq}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjfubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhjbubjJ)}(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&]uh1hhj}hMhj~ubah}(h]h ]h"]h$]h&]uh1jIhjbubeh}(h]h ]h"]h$]h&]uh1j)hj}hMhj&ubeh}(h]h ]h"]h$]h&]uh1j$hj ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj ubh)}(hUse this function to get the regulatory rule for a specific frequency on a given wireless device. If the device has a specific regulatory domain it wants to follow we respect that unless a country IE has been received and processed already.h]hUse this function to get the regulatory rule for a specific frequency on a given wireless device. If the device has a specific regulatory domain it wants to follow we respect that unless a country IE has been received and processed already.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj ubh)}(h **Return**h]j)}(hjʆh]hReturn}(hj̆hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjȆubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:149: ./include/net/cfg80211.hhMhj ubh)}(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.hhMhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubeh}(h]%regulatory-enforcement-infrastructureah ]h"]%regulatory enforcement infrastructureah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(hRFkill integrationh]hRFkill integration}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh)}(hX8RFkill integration in cfg80211 is almost invisible to drivers, as cfg80211 automatically registers an rfkill instance for each wireless device it knows about. Soft kill is also translated into disconnecting and turning all interfaces off. Drivers are expected to turn off the device when all interfaces are down.h]hX8RFkill integration in cfg80211 is almost invisible to drivers, as cfg80211 automatically registers an rfkill instance for each wireless device it knows about. Soft kill is also translated into disconnecting and turning all interfaces off. Drivers are expected to turn off the device when all interfaces are down.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:158: ./include/net/cfg80211.hhM!hjhhubh)}(hHowever, devices may have a hard RFkill line, in which case they also need to interact with the rfkill subsystem, via cfg80211. They can do this with a few helper functions documented here.h]hHowever, devices may have a hard RFkill line, in which case they also need to interact with the rfkill subsystem, via cfg80211. They can do this with a few helper functions documented here.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:158: ./include/net/cfg80211.hhM !hjhhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js'wiphy_rfkill_start_polling (C function)c.wiphy_rfkill_start_pollinghNtauh1jfhjhhhNhNubjx)}(hhh](j})}(h5void wiphy_rfkill_start_polling (struct wiphy *wiphy)h]j)}(h4void wiphy_rfkill_start_polling(struct wiphy *wiphy)h](j)}(hvoidh]hvoid}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM!!ubj)}(h h]h }(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBhhhjThM!!ubj)}(hwiphy_rfkill_start_pollingh]j)}(hwiphy_rfkill_start_pollingh]hwiphy_rfkill_start_polling}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcubah}(h]h ](jjeh"]h$]h&]jjuh1jhjBhhhjThM!!ubj)}(h(struct wiphy *wiphy)h]j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jf)}j^jisbc.wiphy_rfkill_start_pollingasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjχhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hwiphyh]hwiphy}(hj܇hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj{ubah}(h]h ]h"]h$]h&]jjuh1jhjBhhhjThM!!ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj>hhhjThM!!ubah}(h]j9ah ](jjeh"]h$]h&]jj)jhuh1j|hjThM!!hj;hhubj)}(hhh]h)}(hstart polling rfkillh]hstart polling rfkill}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM!!hjhhubah}(h]h ]h"]h$]h&]uh1jhj;hhhjThM!!ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjjjjjjuh1jwhhhjhNhNubj)}(h3**Parameters** ``struct wiphy *wiphy`` the wiphyh](h)}(h**Parameters**h]j)}(hj(h]h Parameters}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM%!hj"ubj%)}(hhh]j*)}(h!``struct wiphy *wiphy`` the wiphyh](j0)}(h``struct wiphy *wiphy``h]j,)}(hjGh]hstruct wiphy *wiphy}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjEubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM'!hjAubjJ)}(hhh]h)}(h the wiphyh]h the wiphy}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM"!hj]ubah}(h]h ]h"]h$]h&]uh1jIhjAubeh}(h]h ]h"]h$]h&]uh1j)hj\hM'!hj>ubah}(h]h ]h"]h$]h&]uh1j$hj"ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js&wiphy_rfkill_stop_polling (C function)c.wiphy_rfkill_stop_pollinghNtauh1jfhjhhhNhNubjx)}(hhh](j})}(h4void wiphy_rfkill_stop_polling (struct wiphy *wiphy)h]j)}(h3void wiphy_rfkill_stop_polling(struct wiphy *wiphy)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM'!ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM'!ubj)}(hwiphy_rfkill_stop_pollingh]j)}(hwiphy_rfkill_stop_pollingh]hwiphy_rfkill_stop_polling}(hjˆhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM'!ubj)}(h(struct wiphy *wiphy)h]j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hjވhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjڈ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&] refdomainj8reftypej^ reftargetjmodnameN classnameNj j )}j ]jf)}j^jĈsbc.wiphy_rfkill_stop_pollingasbuh1hhjڈubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjڈubjz)}(hj}h]h*}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjڈubj)}(hwiphyh]hwiphy}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjڈubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjֈubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM'!ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM'!ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhM'!hjhhubj)}(hhh]h)}(hstop polling rfkillh]hstop polling rfkill}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM'!hj^hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM'!ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjyjjyjjjuh1jwhhhjhNhNubj)}(h3**Parameters** ``struct wiphy *wiphy`` the wiphyh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM+!hj}ubj%)}(hhh]j*)}(h!``struct wiphy *wiphy`` the wiphyh](j0)}(h``struct wiphy *wiphy``h]j,)}(hjh]hstruct wiphy *wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM-!hjubjJ)}(hhh]h)}(h the wiphyh]h the wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:161: ./include/net/cfg80211.hhM(!hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM-!hjubah}(h]h ]h"]h$]h&]uh1j$hj}ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubeh}(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.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:170: ./include/net/cfg80211.hhM!hjhhubh)}(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.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:170: ./include/net/cfg80211.hhM!hjhhubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js.cfg80211_testmode_alloc_reply_skb (C function)#c.cfg80211_testmode_alloc_reply_skbhNtauh1jfhjhhhNhNubjx)}(hhh](j})}(hWstruct sk_buff * cfg80211_testmode_alloc_reply_skb (struct wiphy *wiphy, int approxlen)h]j)}(hUstruct sk_buff *cfg80211_testmode_alloc_reply_skb(struct wiphy *wiphy, int approxlen)h](j)}(hjh]hstruct}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/hhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!ubj)}(h h]h }(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/hhhj@hM!ubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjTmodnameN classnameNj j )}j ]jf)}j^!cfg80211_testmode_alloc_reply_skbsb#c.cfg80211_testmode_alloc_reply_skbasbuh1hhj/hhhj@hM!ubj)}(h h]h }(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/hhhj@hM!ubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj/hhhj@hM!ubj)}(h!cfg80211_testmode_alloc_reply_skbh]j)}(hjph]h!cfg80211_testmode_alloc_reply_skb}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhj/hhhj@hM!ubj)}(h$(struct wiphy *wiphy, int approxlen)h](j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(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&] refdomainj8reftypej^ reftargetj͊modnameN classnameNj j )}j ]jn#c.cfg80211_testmode_alloc_reply_skbasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hwiphyh]hwiphy}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(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}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubeh}(h]h ]h"]h$]h&]jjuh1jhj/hhhj@hM!ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhj+hhhj@hM!ubah}(h]j&ah ](jjeh"]h$]h&]jj)jhuh1j|hj@hM!hj(hhubj)}(hhh]h)}(hallocate testmode replyh]hallocate testmode reply}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!hj`hhubah}(h]h ]h"]h$]h&]uh1jhj(hhhj@hM!ubeh}(h]h ](j8functioneh"]h$]h&]jj8jj{jj{jjjuh1jwhhhjhNhNubj)}(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.yh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!hjubj%)}(hhh](j*)}(h"``struct wiphy *wiphy`` the wiphy h](j0)}(h``struct wiphy *wiphy``h]j,)}(hjh]hstruct wiphy *wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!hjubjJ)}(hhh]h)}(h the wiphyh]h the wiphy}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM!hjubj*)}(hY``int approxlen`` an upper bound of the length of the data that will be put into the skb h](j0)}(h``int approxlen``h]j,)}(hj݋h]h int approxlen}(hjߋhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjۋubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!hj׋ubjJ)}(hhh]h)}(hFan upper bound of the length of the data that will be put into the skbh]hFan upper bound of the length of the data that will be put into the skb}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!hjubah}(h]h ]h"]h$]h&]uh1jIhj׋ubeh}(h]h ]h"]h$]h&]uh1j)hjhM!hjubeh}(h]h ]h"]h$]h&]uh1j$hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!hjubh)}(hThis function allocates and pre-fills an skb for a reply to the testmode command. Since it is intended for a reply, calling it outside of the **testmode_cmd** operation is invalid.h](hThis function allocates and pre-fills an skb for a reply to the testmode command. Since it is intended for a reply, calling it outside of the }(hj/hhhNhNubj)}(h**testmode_cmd**h]h testmode_cmd}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubh operation is invalid.}(hj/hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!hjubh)}(hXThe returned skb is pre-filled with the wiphy index and set up in a way that any data that is put into the skb (with skb_put(), nla_put() or similar) will end up being within the ``NL80211_ATTR_TESTDATA`` attribute, so all that needs to be done with the skb is adding data for the corresponding userspace tool which can then read that data out of the testdata attribute. You must not modify the skb in any other way.h](hThe returned skb is pre-filled with the wiphy index and set up in a way that any data that is put into the skb (with skb_put(), nla_put() or similar) will end up being within the }(hjPhhhNhNubj,)}(h``NL80211_ATTR_TESTDATA``h]hNL80211_ATTR_TESTDATA}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjPubh 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.}(hjPhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!hjubh)}(hWhen done, call cfg80211_testmode_reply() with the skb and return its error code as the result of the **testmode_cmd** operation.h](hfWhen done, call cfg80211_testmode_reply() with the skb and return its error code as the result of the }(hjqhhhNhNubj)}(h**testmode_cmd**h]h testmode_cmd}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubh operation.}(hjqhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!hjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!hjubh)}(h?An allocated and pre-filled skb. ``NULL`` if any errors happen.h](h!An allocated and pre-filled skb. }(hjhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubh if any errors happen.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM!hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js$cfg80211_testmode_reply (C function)c.cfg80211_testmode_replyhNtauh1jfhjhhhNhNubjx)}(hhh](j})}(h1int cfg80211_testmode_reply (struct sk_buff *skb)h]j)}(h0int cfg80211_testmode_reply(struct sk_buff *skb)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM"ubj)}(hcfg80211_testmode_replyh]j)}(hcfg80211_testmode_replyh]hcfg80211_testmode_reply}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM"ubj)}(h(struct sk_buff *skb)h]j%)}(hstruct sk_buff *skbh](j)}(hjh]hstruct}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubj)}(h h]h }(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjHmodnameN classnameNj j )}j ]jf)}j^jsbc.cfg80211_testmode_replyasbuh1hhj$ubj)}(h h]h }(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubjz)}(hj}h]h*}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhj$ubj)}(hskbh]hskb}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$ubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hj ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM"ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM"ubah}(h]jތah ](jjeh"]h$]h&]jj)jhuh1j|hjhM"hjhhubj)}(hhh]h)}(hsend the reply skbh]hsend the reply skb}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM"ubeh}(h]h ](j8functioneh"]h$]h&]jj8jjÍjjÍjjjuh1jwhhhjhNhNubj)}(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)}(hj͍h]h Parameters}(hjύhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjˍubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hjǍubj%)}(hhh]j*)}(hc``struct sk_buff *skb`` The skb, must have been allocated with cfg80211_testmode_alloc_reply_skb() h](j0)}(h``struct sk_buff *skb``h]j,)}(hjh]hstruct sk_buff *skb}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hjubjJ)}(hhh]h)}(hJThe skb, must have been allocated with cfg80211_testmode_alloc_reply_skb()h]hJThe skb, must have been allocated with cfg80211_testmode_alloc_reply_skb()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjubah}(h]h ]h"]h$]h&]uh1j$hjǍubh)}(h**Description**h]j)}(hj(h]h Description}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hjǍubh)}(hSince calling this function will usually be the last thing before returning from the **testmode_cmd** you should return the error code. Note that this function consumes the skb regardless of the return value.h](hUSince calling this function will usually be the last thing before returning from the }(hj>hhhNhNubj)}(h**testmode_cmd**h]h testmode_cmd}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubhl you should return the error code. Note that this function consumes the skb regardless of the return value.}(hj>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hjǍubh)}(h **Return**h]j)}(hjah]hReturn}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM "hjǍubh)}(hAn error code or 0 on success.h]hAn error code or 0 on success.}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM "hjǍubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js.cfg80211_testmode_alloc_event_skb (C function)#c.cfg80211_testmode_alloc_event_skbhNtauh1jfhjhhhNhNubjx)}(hhh](j})}(hbstruct sk_buff * cfg80211_testmode_alloc_event_skb (struct wiphy *wiphy, int approxlen, gfp_t gfp)h]j)}(h`struct sk_buff *cfg80211_testmode_alloc_event_skb(struct wiphy *wiphy, int approxlen, gfp_t gfp)h](j)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM"ubh)}(hhh]j)}(hsk_buffh]hsk_buff}(hjŎhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjŽubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetjǎmodnameN classnameNj j )}j ]jf)}j^!cfg80211_testmode_alloc_event_skbsb#c.cfg80211_testmode_alloc_event_skbasbuh1hhjhhhjhM"ubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhM"ubjz)}(hj}h]h*}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjhhhjhM"ubj)}(h!cfg80211_testmode_alloc_event_skbh]j)}(hjh]h!cfg80211_testmode_alloc_event_skb}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]jjuh1jhjhhhjhM"ubj)}(h/(struct wiphy *wiphy, int approxlen, gfp_t gfp)h](j%)}(hstruct wiphy *wiphyh](j)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hwiphyh]hwiphy}(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&] refdomainj8reftypej^ reftargetj@modnameN classnameNj j )}j ]j#c.cfg80211_testmode_alloc_event_skbasbuh1hhjubj)}(h h]h }(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjz)}(hj}h]h*}(hjjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jyhjubj)}(hwiphyh]hwiphy}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(h int approxlenh](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h approxlenh]h approxlen}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubj%)}(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&] refdomainj8reftypej^ reftargetjʏmodnameN classnameNj j )}j ]j#c.cfg80211_testmode_alloc_event_skbasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hgfph]hgfp}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphjjuh1j$hjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM"ubeh}(h]h ]h"]h$]h&]jjjuh1jjjhjhhhjhM"ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j|hjhM"hjhhubj)}(hhh]h)}(hallocate testmode eventh]hallocate testmode event}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM"ubeh}(h]h ](j8functioneh"]h$]h&]jj8jj6jj6jjjuh1jwhhhjhNhNubj)}(hX**Parameters** ``struct wiphy *wiphy`` the wiphy ``int approxlen`` an upper bound of the length of the data that will be put into the skb ``gfp_t gfp`` allocation flags **Description** This function allocates and pre-fills an skb for an event on the testmode multicast group. The returned skb is set up in the same way as with cfg80211_testmode_alloc_reply_skb() but prepared for an event. As there, you should simply add data to it that will then end up in the ``NL80211_ATTR_TESTDATA`` attribute. Again, you must not modify the skb in any other way. When done filling the skb, call cfg80211_testmode_event() with the skb to send the event. **Return** An allocated and pre-filled skb. ``NULL`` if any errors happen.h](h)}(h**Parameters**h]j)}(hj@h]h Parameters}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hj:ubj%)}(hhh](j*)}(h"``struct wiphy *wiphy`` the wiphy h](j0)}(h``struct wiphy *wiphy``h]j,)}(hj_h]hstruct wiphy *wiphy}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj]ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hjYubjJ)}(hhh]h)}(h the wiphyh]h the wiphy}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjthM"hjuubah}(h]h ]h"]h$]h&]uh1jIhjYubeh}(h]h ]h"]h$]h&]uh1j)hjthM"hjVubj*)}(hY``int approxlen`` an upper bound of the length of the data that will be put into the skb h](j0)}(h``int approxlen``h]j,)}(hjh]h int approxlen}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hjubjJ)}(hhh]h)}(hFan upper bound of the length of the data that will be put into the skbh]hFan upper bound of the length of the data that will be put into the skb}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hjubah}(h]h ]h"]h$]h&]uh1jIhjubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjVubj*)}(h``gfp_t gfp`` allocation flags h](j0)}(h ``gfp_t gfp``h]j,)}(hjҐh]h gfp_t gfp}(hjԐhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjАubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hj̐ubjJ)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1jIhj̐ubeh}(h]h ]h"]h$]h&]uh1j)hjhM"hjVubeh}(h]h ]h"]h$]h&]uh1j$hj:ubh)}(h**Description**h]j)}(hj h]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hj:ubh)}(hZThis function allocates and pre-fills an skb for an event on the testmode multicast group.h]hZThis function allocates and pre-fills an skb for an event on the testmode multicast group.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hj:ubh)}(hXThe returned skb is set up in the same way as with cfg80211_testmode_alloc_reply_skb() but prepared for an event. As there, you should simply add data to it that will then end up in the ``NL80211_ATTR_TESTDATA`` attribute. Again, you must not modify the skb in any other way.h](hThe returned skb is set up in the same way as with cfg80211_testmode_alloc_reply_skb() but prepared for an event. As there, you should simply add data to it that will then end up in the }(hj2hhhNhNubj,)}(h``NL80211_ATTR_TESTDATA``h]hNL80211_ATTR_TESTDATA}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj2ubh@ attribute. Again, you must not modify the skb in any other way.}(hj2hhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM"hj:ubh)}(hYWhen done filling the skb, call cfg80211_testmode_event() with the skb to send the event.h]hYWhen done filling the skb, call cfg80211_testmode_event() with the skb to send the event.}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM "hj:ubh)}(h **Return**h]j)}(hjdh]hReturn}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM#"hj:ubh)}(h?An allocated and pre-filled skb. ``NULL`` if any errors happen.h](h!An allocated and pre-filled skb. }(hjzhhhNhNubj,)}(h``NULL``h]hNULL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1j+hjzubh if any errors happen.}(hjzhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM$"hj:ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubjg)}(hhh]h}(h]h ]h"]h$]h&]entries](js$cfg80211_testmode_event (C function)c.cfg80211_testmode_eventhNtauh1jfhjhhhNhNubjx)}(hhh](j})}(h=void cfg80211_testmode_event (struct sk_buff *skb, gfp_t gfp)h]j)}(hh]h gfp_t gfp}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1j+hj<ubah}(h]h ]h"]h$]h&]uh1j/ha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM2"hj8ubjJ)}(hhh]h)}(hallocation flagsh]hallocation flags}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShM2"hjTubah}(h]h ]h"]h$]h&]uh1jIhj8ubeh}(h]h ]h"]h$]h&]uh1j)hjShM2"hjubeh}(h]h ]h"]h$]h&]uh1j$hjߒubh)}(h**Description**h]j)}(hjyh]h Description}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/driver-api/80211/cfg80211:173: ./include/net/cfg80211.hhM4"hjߒubh)}(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&]uh1jhjubhl, 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.hhM3"hjߒubeh}(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}(jējj`cj]cji=jf=j[djXdj;tj8tjjjjjjjju nametypes}(jēj`cji=j[dj;tjjjjuh}(jhj]chjuj~jjj j jjj+j0j?jDjjjjjjjjjQ$jV$j%j%jt)jy)jxBj}BjDjDjEjEjGjGjIjIjaKjfKjMjMj`OjeOjPjPjj>jEEjJEjYIj^IjOjOjQjQjTjTjVjVj'[j,[j8bj=bj8tj^djdjdjlfjqfjgjgjijjjljljpjpjrjrjj>tjjtjotj0wj5wjN}jS}jjjjj>jCjjjjj9j>jjjjj&j+jތjjjjju 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.