Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp3799764pxj; Tue, 11 May 2021 12:06:59 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwFylPQ1wtButtzgm++2mqeXlohRU/o3mDkYom9vAuWV2lw3CR8LMS7QAA7dQUqNmWZmSM3 X-Received: by 2002:a05:6402:323:: with SMTP id q3mr38777651edw.69.1620760019366; Tue, 11 May 2021 12:06:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620760019; cv=none; d=google.com; s=arc-20160816; b=yyT0r1cdmQfvmoh20rLkxBOiQc5Xr48tOxY7W+6nquRm06nYZ7Zz1lp44bRThwZJo9 cM7qzycfFyS3PplNjaHMvVN74haUpEmJPQ7xEaPS3KXxuqbZTsvFrcHXjq3wFqYv72M4 B0hvedq2TYrHaBXIU0ze1JWqeoTmR+nahzTLWcsQfTWDJcNqSgoJF3vY1bkYP/+w+5u8 78xW0fJZpevy6JjxSRPGB0mxkXgWMJMNATYd7EjCpWBw34hQl8z2FGAjkLwM3D0nj+jB TlccwiRzPTnzjND2O9AnJft47Jgly+FbUd4imp6Dh2dorbZrTPtZPtAeENpqIGG1Lerp DJdw== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=rLO7o5Zr7KK/J1TQ3wu6G6xEI85J0pU/yShkNehBW8I=; b=WSEhYWPtxJnxpX3LrDkPvLznD5EFvssN0m31s5AnAiAViAiceyGHivK4xWM0mOpdIb 8DEhMKyD47Sgymn9XdLBwj3w/j08rOLxoHYgn9MXo5yn3Ob4o2g/jmDkC7BuH1vXF0gH OLtQ17oDarK0uBbY2slBoVlZPf01bA4/yDZkYXd4EOpvtvEoFZnxjc1HmFaSZJJoDFzD KC/c55jCSG4FFSwuGL4tGEDQZlP0LYr5ktg5vqQ8HmK4vPSQblEeFvHB9EGPmfi3sf8Z e2sqchb/VLbJtbjtKgKYZaS3iUI6ebdOkIztL4fD97U3t+z97H0upxcwwigYhKaAFiwO IApQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k22si1375946ejc.469.2021.05.11.12.06.35; Tue, 11 May 2021 12:06:59 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232084AbhEKTGr (ORCPT + 99 others); Tue, 11 May 2021 15:06:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55562 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231439AbhEKTGq (ORCPT ); Tue, 11 May 2021 15:06:46 -0400 Received: from plekste.mt.lv (bute.mt.lv [IPv6:2a02:610:7501:2000::195]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A3216C061574; Tue, 11 May 2021 12:05:39 -0700 (PDT) Received: from [2a02:610:7501:feff:1ccf:41ff:fe50:18b9] (helo=localhost.localdomain) by plekste.mt.lv with esmtpsa (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.89) (envelope-from ) id 1lgXhB-0004HR-3l; Tue, 11 May 2021 22:05:29 +0300 From: Gatis Peisenieks To: chris.snook@gmail.com, davem@davemloft.net, kuba@kernel.org, hkallweit1@gmail.com, jesse.brandeburg@intel.com, dchickles@marvell.com, tully@mikrotik.com, eric.dumazet@gmail.com Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Gatis Peisenieks Subject: [PATCH net-next 4/4] atl1c: enable rx csum offload on Mikrotik 10/25G NIC Date: Tue, 11 May 2021 22:05:18 +0300 Message-Id: <20210511190518.8901-5-gatis@mikrotik.com> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210511190518.8901-1-gatis@mikrotik.com> References: <20210511190518.8901-1-gatis@mikrotik.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Mikrotik 10/25G NIC supports hw checksum verification on rx for IP/IPv6 + TCP/UDP packets. HW checksum offload helps reduce host cpu load. This enables the csum offload specifically for Mikrotik 10/25G NIC as other HW supported by the driver is known to have problems with it. TCP iperf3 to Threadripper 3960X with NIC improved 16.5 -> 20.0 Gbps with mtu=1500. Signed-off-by: Gatis Peisenieks --- drivers/net/ethernet/atheros/atl1c/atl1c.h | 2 ++ drivers/net/ethernet/atheros/atl1c/atl1c_main.c | 5 +++++ 2 files changed, 7 insertions(+) diff --git a/drivers/net/ethernet/atheros/atl1c/atl1c.h b/drivers/net/ethernet/atheros/atl1c/atl1c.h index 3fda7eb3bd69..9d70cb7544f1 100644 --- a/drivers/net/ethernet/atheros/atl1c/atl1c.h +++ b/drivers/net/ethernet/atheros/atl1c/atl1c.h @@ -241,6 +241,8 @@ struct atl1c_tpd_ext_desc { #define RRS_PACKET_PROT_IS_IPV6_ONLY(word) \ ((((word) >> RRS_PROT_ID_SHIFT) & RRS_PROT_ID_MASK) == 6) +#define RRS_MT_PROT_ID_TCPUDP BIT(19) + struct atl1c_recv_ret_status { __le32 word0; __le32 rss_hash; diff --git a/drivers/net/ethernet/atheros/atl1c/atl1c_main.c b/drivers/net/ethernet/atheros/atl1c/atl1c_main.c index c34ad1c3a532..7bb5631d9922 100644 --- a/drivers/net/ethernet/atheros/atl1c/atl1c_main.c +++ b/drivers/net/ethernet/atheros/atl1c/atl1c_main.c @@ -1670,6 +1670,11 @@ static irqreturn_t atl1c_intr(int irq, void *data) static inline void atl1c_rx_checksum(struct atl1c_adapter *adapter, struct sk_buff *skb, struct atl1c_recv_ret_status *prrs) { + if (adapter->hw.nic_type == athr_mt) { + if (prrs->word3 & RRS_MT_PROT_ID_TCPUDP) + skb->ip_summed = CHECKSUM_UNNECESSARY; + return; + } /* * The pid field in RRS in not correct sometimes, so we * cannot figure out if the packet is fragmented or not, -- 2.31.1