Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1251877pxb; Wed, 10 Feb 2021 04:07:48 -0800 (PST) X-Google-Smtp-Source: ABdhPJxUjbSbQUTbPwTvMg0JZeL5TQEF43YVWLO+sBrdjePLatIQ2p3GkVz7p1iNEnAE+eopcdVo X-Received: by 2002:a17:906:f102:: with SMTP id gv2mr2587178ejb.47.1612958868256; Wed, 10 Feb 2021 04:07:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612958868; cv=none; d=google.com; s=arc-20160816; b=Bin0ka8lOUbRPH5NYBrfZqp+1vT1DTZUCRnMeZZGCLJAsOzpC6WHHQbYVhdS27vlyk B4IUUJEz5bb0xJtLZXt4wZpOXHLf1sy6wz77MFFiu0Ly3dhOdnt6Ghci5TQadNh7RCUi dvr9ktcAd0DeMhpkc3gskdL9D19kkCGKoc0gL0F4gUGKYOR/2AUSmAEO839m8eYHSPPF 9L9KrIGYkk4F5HuMhRCOM9pDjbVPaFSzIhjf1vc7XAZNib1MVgMk4WJuRxYF5GzYNatv lnDPXSVTdRUI9V4dXD630803tP208KUps2Jo8B1YUFvuiAoK9dQGnx3XdAZwLbSqciY7 mkWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:subject:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:cc:to:from; bh=tWgglwLomreX5BPN6IrQmyN7cwXd0ZQRh6Re3eR3RuY=; b=njMLmRP7+J23E5shExA9s+Qp3WxqzrliMUbKpLB95ZhNTaIBTXjAqeB0D+kBTx9nZB rJMNCuhxNtiA/FbKVQiwSeHEtbPcK6RTpx96cyghuWRflujSHZaqz0E+6ONGyc1y1jQ9 KkC0nOIvjIVL8Z5GGELd6FpVU3c6hNyu8PW+4nBT7aevIrW0Prv9rlAhsp+y5LkTTGhI qaswL50mOrRUa6ArTUwqaVQ3Y47NSL3IrEt9keY2TRr12LQPMzWXcIpIDwt7Mwd496H8 4Msi8AitaQVsMnLK5wGCu8yhKWijRKt1ChrIAL0XCyLNgFbobNz94WNPe/xton/QUZPB OFYA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u9si1214889ejr.186.2021.02.10.04.07.24; Wed, 10 Feb 2021 04:07:48 -0800 (PST) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230339AbhBJMEY (ORCPT + 99 others); Wed, 10 Feb 2021 07:04:24 -0500 Received: from paleale.coelho.fi ([176.9.41.70]:45032 "EHLO farmhouse.coelho.fi" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S229754AbhBJMCE (ORCPT ); Wed, 10 Feb 2021 07:02:04 -0500 Received: from 91-156-6-193.elisa-laajakaista.fi ([91.156.6.193] helo=redipa.ger.corp.intel.com) by farmhouse.coelho.fi with esmtpsa (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.93) (envelope-from ) id 1l9o6u-0049Ur-SG; Wed, 10 Feb 2021 13:56:45 +0200 From: Luca Coelho To: kvalo@codeaurora.org Cc: linux-wireless@vger.kernel.org Date: Wed, 10 Feb 2021 13:56:36 +0200 Message-Id: X-Mailer: git-send-email 2.30.0 In-Reply-To: <20210210115637.276676-1-luca@coelho.fi> References: <20210210115637.276676-1-luca@coelho.fi> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on farmhouse.coelho.fi X-Spam-Level: X-Spam-Status: No, score=-2.9 required=5.0 tests=ALL_TRUSTED,BAYES_00, TVD_RCVD_IP autolearn=ham autolearn_force=no version=3.4.4 Subject: [PATCH v2 11/12] iwlwifi: when HW has rate offload don't look at control field Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org From: Mordechay Goodstein Control field is set by mac80211 only if case rate is not offloaded to hw. Signed-off-by: Mordechay Goodstein Signed-off-by: Luca Coelho --- drivers/net/wireless/intel/iwlwifi/mvm/tx.c | 22 ++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/drivers/net/wireless/intel/iwlwifi/mvm/tx.c b/drivers/net/wireless/intel/iwlwifi/mvm/tx.c index 871e9daf56f8..1ad621d13ad3 100644 --- a/drivers/net/wireless/intel/iwlwifi/mvm/tx.c +++ b/drivers/net/wireless/intel/iwlwifi/mvm/tx.c @@ -265,20 +265,24 @@ static u32 iwl_mvm_get_tx_rate(struct iwl_mvm *mvm, struct ieee80211_tx_info *info, struct ieee80211_sta *sta, __le16 fc) { - int rate_idx; + int rate_idx = -1; u8 rate_plcp; u32 rate_flags = 0; struct iwl_mvm_sta *mvmsta = iwl_mvm_sta_from_mac80211(sta); - /* HT rate doesn't make sense for a non data frame */ - WARN_ONCE(info->control.rates[0].flags & IEEE80211_TX_RC_MCS && - !ieee80211_is_data(fc), - "Got a HT rate (flags:0x%x/mcs:%d/fc:0x%x/state:%d) for a non data frame\n", - info->control.rates[0].flags, - info->control.rates[0].idx, - le16_to_cpu(fc), mvmsta->sta_state); + /* info->control is only relevant for non HW rate control */ + if (!ieee80211_hw_check(mvm->hw, HAS_RATE_CONTROL)) { + /* HT rate doesn't make sense for a non data frame */ + WARN_ONCE(info->control.rates[0].flags & IEEE80211_TX_RC_MCS && + !ieee80211_is_data(fc), + "Got a HT rate (flags:0x%x/mcs:%d/fc:0x%x/state:%d) for a non data frame\n", + info->control.rates[0].flags, + info->control.rates[0].idx, + le16_to_cpu(fc), mvmsta->sta_state); + + rate_idx = info->control.rates[0].idx; + } - rate_idx = info->control.rates[0].idx; /* if the rate isn't a well known legacy rate, take the lowest one */ if (rate_idx < 0 || rate_idx >= IWL_RATE_COUNT_LEGACY) rate_idx = rate_lowest_index( -- 2.30.0