Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3645281pxb; Mon, 24 Jan 2022 14:17:45 -0800 (PST) X-Google-Smtp-Source: ABdhPJztik3Up4B25FXnzssX3I77Vl6A7YR9fbskoNP+7Ra8gLup/xcXtIRCeGgiO8tw53jajEV0 X-Received: by 2002:a17:90b:3e89:: with SMTP id rj9mr437132pjb.34.1643062665557; Mon, 24 Jan 2022 14:17:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643062665; cv=none; d=google.com; s=arc-20160816; b=uLGAZXltdWdMouWXpDBDF+ueIpwHpDxeIkznJu0OTUDy+CMdIhXMpGS2afX8osHCGw 6cOUQEMF1YsXQGmaGKi6NYHCW+8HWF7G1Nj6xSiT7o6G7tCsp1b6VCUYrVIPR3BZp/bm RF23KGNZUWfCo299jOHFXPPH7JvJVsGok+Y/RVRFl105FFv3s3Zaknq7PuEAcvJXnIww gIcOVmBkYZNNIBeBZIVl1/Yvn10ulZVONpDgjqWcwpkpVTnVLNUAatUbd0wVadL7gcwx AduE3Qd6MyPFJlut3Y8h0TMmw4qsgxOInc41Y/lW5s9M4rw4WDw5Wj11h3Lrnhe1iKy+ os3Q== 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=/hQxjKQ8+uQwLMCm7IyZrDzVx2DUrSzw/sULKfi5p+o=; b=Ts0tDkzvuxpgpSCt7tyrt3TVlYrAAyqEWYRb97rVwwumVVCGREYAX9Vvk//IY0bhS+ //JCAx0TmRtwG0itxHARvotW1+spPkI0OvO/Au+8KlNPldapc+t2WAlq97jo7nVBZ4KX o5JCqmVWLaXH9/HIHrIIInTPedy/Dksrjc8j54JAZy4DaFWbMBIJGZtjJRobMsIovklG swxLIgCynMOtDSvE4dM6ZapOmEhdOC1Qjf/E9UNS7M/9/AHsSHG5jwGTQh2rnLu8Kj4n LGRLqQBxd74w0kw7oiLfioyoDg0pBHrRKc9UEEixuHyDAynH7LhQ9A4NBAUUbJXkEcCz u4Fg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=S5AsVKMy; 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 j10si16212892pgq.831.2022.01.24.14.17.32; Mon, 24 Jan 2022 14:17:45 -0800 (PST) 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=S5AsVKMy; 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 S1581891AbiAXWMg (ORCPT + 99 others); Mon, 24 Jan 2022 17:12:36 -0500 Received: from dfw.source.kernel.org ([139.178.84.217]:49694 "EHLO dfw.source.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1378461AbiAXV3B (ORCPT ); Mon, 24 Jan 2022 16:29:01 -0500 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 0653C61521; Mon, 24 Jan 2022 21:29:00 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id E1BC5C33E60; Mon, 24 Jan 2022 21:28:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643059739; bh=Fl5rzd6FQiE4olvgjq95Hwc7BEQkLP+TG+oqGxrulSU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=S5AsVKMyVxkyfI8OiwnpF4ESGaKIP9+CNk9saiGuRpyctlvDyFsaEvxsjvCFjoRnV Orc2pm3fONc/4LZO8t7IZw25KAtyLxsBAH4E6IaIRqjS7o26KuFFHTvsYUjChRSubK 6jrjKIvlyyzR9UNZ1EkfKbjojcRbqhE5Kgw/dvRY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Danielle Ratson , Ido Schimmel , "David S. Miller" , Sasha Levin Subject: [PATCH 5.16 0717/1039] mlxsw: pci: Avoid flow control for EMAD packets Date: Mon, 24 Jan 2022 19:41:46 +0100 Message-Id: <20220124184149.432272027@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124184125.121143506@linuxfoundation.org> References: <20220124184125.121143506@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: Danielle Ratson [ Upstream commit d43e4271747ace01a27a49a97a397cb4219f6487 ] Locally generated packets ingress the device through its CPU port. When the CPU port is congested and there are not enough credits in its headroom buffer, packets can be dropped. While this might be acceptable for data packets that traverse the network, configuration packets exchanged between the host and the device (EMADs) should not be subjected to this flow control. The "sdq_lp" bit in the SDQ (Send Descriptor Queue) context allows the host to instruct the device to treat packets sent on this queue as "local processing" and always process them, regardless of the state of the CPU port's headroom. Add the definition of this bit and set it for the dedicated SDQ reserved for the transmission of EMAD packets. This makes the "local processing" bit in the WQE (Work Queue Element) redundant, so clear it. Signed-off-by: Danielle Ratson Signed-off-by: Ido Schimmel Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/net/ethernet/mellanox/mlxsw/cmd.h | 12 ++++++++++++ drivers/net/ethernet/mellanox/mlxsw/pci.c | 6 +++++- 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/drivers/net/ethernet/mellanox/mlxsw/cmd.h b/drivers/net/ethernet/mellanox/mlxsw/cmd.h index 392ce3cb27f72..51b260d54237e 100644 --- a/drivers/net/ethernet/mellanox/mlxsw/cmd.h +++ b/drivers/net/ethernet/mellanox/mlxsw/cmd.h @@ -935,6 +935,18 @@ static inline int mlxsw_cmd_sw2hw_rdq(struct mlxsw_core *mlxsw_core, */ MLXSW_ITEM32(cmd_mbox, sw2hw_dq, cq, 0x00, 24, 8); +enum mlxsw_cmd_mbox_sw2hw_dq_sdq_lp { + MLXSW_CMD_MBOX_SW2HW_DQ_SDQ_LP_WQE, + MLXSW_CMD_MBOX_SW2HW_DQ_SDQ_LP_IGNORE_WQE, +}; + +/* cmd_mbox_sw2hw_dq_sdq_lp + * SDQ local Processing + * 0: local processing by wqe.lp + * 1: local processing (ignoring wqe.lp) + */ +MLXSW_ITEM32(cmd_mbox, sw2hw_dq, sdq_lp, 0x00, 23, 1); + /* cmd_mbox_sw2hw_dq_sdq_tclass * SDQ: CPU Egress TClass * RDQ: Reserved diff --git a/drivers/net/ethernet/mellanox/mlxsw/pci.c b/drivers/net/ethernet/mellanox/mlxsw/pci.c index cd3331a077bbf..f91dde4df152b 100644 --- a/drivers/net/ethernet/mellanox/mlxsw/pci.c +++ b/drivers/net/ethernet/mellanox/mlxsw/pci.c @@ -285,6 +285,7 @@ static int mlxsw_pci_sdq_init(struct mlxsw_pci *mlxsw_pci, char *mbox, struct mlxsw_pci_queue *q) { int tclass; + int lp; int i; int err; @@ -292,9 +293,12 @@ static int mlxsw_pci_sdq_init(struct mlxsw_pci *mlxsw_pci, char *mbox, q->consumer_counter = 0; tclass = q->num == MLXSW_PCI_SDQ_EMAD_INDEX ? MLXSW_PCI_SDQ_EMAD_TC : MLXSW_PCI_SDQ_CTL_TC; + lp = q->num == MLXSW_PCI_SDQ_EMAD_INDEX ? MLXSW_CMD_MBOX_SW2HW_DQ_SDQ_LP_IGNORE_WQE : + MLXSW_CMD_MBOX_SW2HW_DQ_SDQ_LP_WQE; /* Set CQ of same number of this SDQ. */ mlxsw_cmd_mbox_sw2hw_dq_cq_set(mbox, q->num); + mlxsw_cmd_mbox_sw2hw_dq_sdq_lp_set(mbox, lp); mlxsw_cmd_mbox_sw2hw_dq_sdq_tclass_set(mbox, tclass); mlxsw_cmd_mbox_sw2hw_dq_log2_dq_sz_set(mbox, 3); /* 8 pages */ for (i = 0; i < MLXSW_PCI_AQ_PAGES; i++) { @@ -1678,7 +1682,7 @@ static int mlxsw_pci_skb_transmit(void *bus_priv, struct sk_buff *skb, wqe = elem_info->elem; mlxsw_pci_wqe_c_set(wqe, 1); /* always report completion */ - mlxsw_pci_wqe_lp_set(wqe, !!tx_info->is_emad); + mlxsw_pci_wqe_lp_set(wqe, 0); mlxsw_pci_wqe_type_set(wqe, MLXSW_PCI_WQE_TYPE_ETHERNET); err = mlxsw_pci_wqe_frag_map(mlxsw_pci, wqe, 0, skb->data, -- 2.34.1