Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2549796pxj; Mon, 10 May 2021 05:43:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzYTomYX4k+eAHOyhi1e0PWvZ1ZHkhew/TdDOxz3wi4KWC9BEu77jpp3cVfo0E03wTqx5KR X-Received: by 2002:a17:907:a076:: with SMTP id ia22mr25313714ejc.233.1620650592954; Mon, 10 May 2021 05:43:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620650592; cv=none; d=google.com; s=arc-20160816; b=KZqtq+NvvLnpJ2xEMWxTZpykIoSJtZnPZZRr8TGD2hq6/JRPd7XI8TDLVYqklUEVcA pllGSk6io+AWY1ciTh87ZRJUoxDoSaujOAx4RkuTnVcwJ0hlB4DCagf2mQLggw175PAi kxn2129AxM3fW3aqIW1xJkbTemb0t9Nsllq24TPxS64mMEWzqhM7+kZPqMU0jqa6+7VB Z6+YC+uCrwx8IPWSbG7w4mWnJ2p0C1nWkr+75JFsTCv7h6B//WPlM8SJK1RqU+DmPX/h kmjPVC/4d302JKblsuuDE8RSmES1kWewUoEis8ZmGWvpGQjLq8RuPefkoPyMm/fK561A 89Xg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=ZxGXCMojEdnKZoQJnNhYQ0LHcdSCHLqeAACN1lQglTM=; b=tbibVVdDZwDQXJvpbobp9EUKTF17b/kCkn6LYb5ZHq/tieePjBYkiNV2dw0VvJvUnu PYPJogDa4VM/IhD8HTgbAN2uim5Lt19jP2qz7CfzXsY8yPPzjdDZ/l+uy9dSWRA49brw G54RWseir/XiYqfs/eE4oDO+1nlQco4MStXODxtMUgFiLWpnmeW4F32IxiHbeW24anxR DrJMct0EsUqub8du5boAHxFCyJUltdfwyXqMZ/aMJrq1F1JL6yF1P2yEbUn3AYzeGgaN DTWQvtENxfCLASgwgtAVXX3siZ2Wkfp/wfKkTnLiRxOwU8dj2/Gq3/OGecQkvLK9Awdi yZ3A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="q7g8/QcJ"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ay17si15315935ejb.496.2021.05.10.05.42.49; Mon, 10 May 2021 05:43:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="q7g8/QcJ"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1347534AbhEJMgR (ORCPT + 99 others); Mon, 10 May 2021 08:36:17 -0400 Received: from mail.kernel.org ([198.145.29.99]:53736 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235285AbhEJLN6 (ORCPT ); Mon, 10 May 2021 07:13:58 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 61E036108B; Mon, 10 May 2021 11:10:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620645031; bh=tP1U7H4312HGX/MWFARpFwLuhVw15lE1SvLcNcr+1OQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=q7g8/QcJgzfgXnDKWKox20A9Gtmwn24O3R/Bt4hQ8ykmEULUAL42+7RT/1tnVPECh 78jbTdyqqIbpBu4FPj+AiQ9wFAEYpxH/GsyilJ8MYFgmptWn0oDVt+qbuHzATPwr27 5aMpKGh6tcXGs4qLKSH/ZI/1BucZlTNJPt37MUnU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Trevor Hemsley , Edward Cree , "David S. Miller" Subject: [PATCH 5.12 323/384] sfc: farch: fix TX queue lookup in TX flush done handling Date: Mon, 10 May 2021 12:21:52 +0200 Message-Id: <20210510102025.446234284@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510102014.849075526@linuxfoundation.org> References: <20210510102014.849075526@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Edward Cree commit 5b1faa92289b53cad654123ed2bc8e10f6ddd4ac upstream. We're starting from a TXQ instance number ('qid'), not a TXQ type, so efx_get_tx_queue() is inappropriate (and could return NULL, leading to panics). Fixes: 12804793b17c ("sfc: decouple TXQ type from label") Reported-by: Trevor Hemsley Cc: stable@vger.kernel.org Signed-off-by: Edward Cree Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- drivers/net/ethernet/sfc/farch.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) --- a/drivers/net/ethernet/sfc/farch.c +++ b/drivers/net/ethernet/sfc/farch.c @@ -1081,16 +1081,16 @@ static void efx_farch_handle_tx_flush_done(struct efx_nic *efx, efx_qword_t *event) { struct efx_tx_queue *tx_queue; + struct efx_channel *channel; int qid; qid = EFX_QWORD_FIELD(*event, FSF_AZ_DRIVER_EV_SUBDATA); if (qid < EFX_MAX_TXQ_PER_CHANNEL * (efx->n_tx_channels + efx->n_extra_tx_channels)) { - tx_queue = efx_get_tx_queue(efx, qid / EFX_MAX_TXQ_PER_CHANNEL, - qid % EFX_MAX_TXQ_PER_CHANNEL); - if (atomic_cmpxchg(&tx_queue->flush_outstanding, 1, 0)) { + channel = efx_get_tx_channel(efx, qid / EFX_MAX_TXQ_PER_CHANNEL); + tx_queue = channel->tx_queue + (qid % EFX_MAX_TXQ_PER_CHANNEL); + if (atomic_cmpxchg(&tx_queue->flush_outstanding, 1, 0)) efx_farch_magic_event(tx_queue->channel, EFX_CHANNEL_MAGIC_TX_DRAIN(tx_queue)); - } } }