iwlwifi: mvm: handle BAR_FRAME_RELEASE (0xc2) notification
In prior hardware generations (e.g. 9000 series), we received the BAR frame with fake NSSN information to handle releasing frames from the reorder buffer for the default queue, the other queues were getting the FRAME_RELEASE notification in this case. With multi-TID block-ack, the firmware no longer sends us the BAR frame because the fake RX is quite big (just the metadata is around 48 bytes or so). Instead, it now sends us one (or multiple) special release notifications (0xc2). The hardware consumes these as well, but only generates the FRAME_RELEASE (0xc3) for queues other than the default queue. We thus need to handle them in the same way we handle the normal FRAME_RELEASE. Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: Luca Coelho <luciano.coelho@intel.com>
This commit is contained in:
committed by
Luca Coelho
parent
0968fbfa41
commit
fe69b7d124
@ -474,6 +474,13 @@ enum iwl_legacy_cmds {
|
||||
*/
|
||||
REPLY_RX_MPDU_CMD = 0xc1,
|
||||
|
||||
/**
|
||||
* @BAR_FRAME_RELEASE: Frame release from BAR notification, used for
|
||||
* multi-TID BAR (previously, the BAR frame itself was reported
|
||||
* instead). Uses &struct iwl_bar_frame_release.
|
||||
*/
|
||||
BAR_FRAME_RELEASE = 0xc2,
|
||||
|
||||
/**
|
||||
* @FRAME_RELEASE:
|
||||
* Frame release (reorder helper) notification, uses
|
||||
|
@ -746,6 +746,38 @@ struct iwl_frame_release {
|
||||
__le16 nssn;
|
||||
};
|
||||
|
||||
/**
|
||||
* enum iwl_bar_frame_release_sta_tid - STA/TID information for BAR release
|
||||
* @IWL_BAR_FRAME_RELEASE_TID_MASK: TID mask
|
||||
* @IWL_BAR_FRAME_RELEASE_STA_MASK: STA mask
|
||||
*/
|
||||
enum iwl_bar_frame_release_sta_tid {
|
||||
IWL_BAR_FRAME_RELEASE_TID_MASK = 0x0000000f,
|
||||
IWL_BAR_FRAME_RELEASE_STA_MASK = 0x000001f0,
|
||||
};
|
||||
|
||||
/**
|
||||
* enum iwl_bar_frame_release_ba_info - BA information for BAR release
|
||||
* @IWL_BAR_FRAME_RELEASE_NSSN_MASK: NSSN mask
|
||||
* @IWL_BAR_FRAME_RELEASE_SN_MASK: SN mask (ignored by driver)
|
||||
* @IWL_BAR_FRAME_RELEASE_BAID_MASK: BAID mask
|
||||
*/
|
||||
enum iwl_bar_frame_release_ba_info {
|
||||
IWL_BAR_FRAME_RELEASE_NSSN_MASK = 0x00000fff,
|
||||
IWL_BAR_FRAME_RELEASE_SN_MASK = 0x00fff000,
|
||||
IWL_BAR_FRAME_RELEASE_BAID_MASK = 0x3f000000,
|
||||
};
|
||||
|
||||
/**
|
||||
* struct iwl_bar_frame_release - frame release from BAR info
|
||||
* @sta_tid: STA & TID information, see &enum iwl_bar_frame_release_sta_tid.
|
||||
* @ba_info: BA information, see &enum iwl_bar_frame_release_ba_info.
|
||||
*/
|
||||
struct iwl_bar_frame_release {
|
||||
__le32 sta_tid;
|
||||
__le32 ba_info;
|
||||
} __packed; /* RX_BAR_TO_FRAME_RELEASE_API_S_VER_1 */
|
||||
|
||||
enum iwl_rss_hash_func_en {
|
||||
IWL_RSS_HASH_TYPE_IPV4_TCP,
|
||||
IWL_RSS_HASH_TYPE_IPV4_UDP,
|
||||
|
Reference in New Issue
Block a user