Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp9813pxv; Wed, 21 Jul 2021 14:02:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxmjhi6KCDrKwe7UCrvlVix8TyAdo0/SpFd69E+c76BK1Dj6Y5qKHPveaeD3DgPoAnTJ1gZ X-Received: by 2002:a05:6638:289:: with SMTP id c9mr33009213jaq.14.1626901373104; Wed, 21 Jul 2021 14:02:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626901373; cv=none; d=google.com; s=arc-20160816; b=aSA58K6eXjvVwqd+iwNs2PQA6D3cWUphk9VITZDwz2fMuRN4OvkP4Tt+lDOMvhGs8q oI8vhyPUVLbmjV/uPvXpvdaI1undjlMidRfIiHWg0orl47j3RDmNa005oFH43IqJbDiZ tnvSK7JmzW8vNVMfAve4I+gY4CTjkkmvj5V7tKGapiWN/fCo8SLyh1bBxi3n2FW5aH8j /frjVMVkJpOBdzTimJcN5A5iRffY4BkoIiJWVvdK3ltzJtvpUuDfHdfPTInmc8vksk6I 1VzK2SEgdn3/3JDJK/+cwVq9lPD6kfGWzxrmo5S6Z2saw6COYQchmtpdTo2RRhTPKSw9 +b9A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=i7PLflitrAYc1ojvfYP6jnVUAWgG4SsQdyVSTkIdSQc=; b=izDKOUGyk42Ho9ZYV6y3klJvQWs4+mzWGJFGFyVfTH+/pCVwgRiZP+xf5Qnf8fQYFN 621naoPQ1+X7KDWzwhxWDePO8lkATiELqqwI4VVQaWJuu477l80wQSvrdMcKhVTbkFUp WZz/LBtbcyn0Ta8gnrU+WuDCj6jVmL93Cs2i+LjnRkcecLI8F+sz3F5OJ3PgR5r4Fzyv MBwFj5zWJ0LDcK1Mkeq+9Y3y3E7avfnyyy+GPwGf4PRtSK62ilDtsh0wPGusppHtBkd7 gHtSOAvxKioNW0LuFuln+xl0ovID46msfrk8rQg2Ah9RQCYbzvxA87GOnn/x4ty1Ucy5 lI9A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=iQDxk669; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y1si29427343jab.59.2021.07.21.14.02.35; Wed, 21 Jul 2021 14:02:53 -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=@google.com header.s=20161025 header.b=iQDxk669; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240009AbhGUO4d (ORCPT + 99 others); Wed, 21 Jul 2021 10:56:33 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43448 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239989AbhGUO4c (ORCPT ); Wed, 21 Jul 2021 10:56:32 -0400 Received: from mail-lj1-x22b.google.com (mail-lj1-x22b.google.com [IPv6:2a00:1450:4864:20::22b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CF00CC061757 for ; Wed, 21 Jul 2021 08:37:08 -0700 (PDT) Received: by mail-lj1-x22b.google.com with SMTP id t3so3552843ljc.3 for ; Wed, 21 Jul 2021 08:37:08 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=i7PLflitrAYc1ojvfYP6jnVUAWgG4SsQdyVSTkIdSQc=; b=iQDxk669PHPJ3JK0QPn1UuRoWl+P7D6lRGEfG2KuJlRDFoJFl5osPA1cxkLOVNHnt5 CEUE4ZCxoaU7pfB2lv4TK++7glpEShMgjeuDjpENcjlbJPxbmhUgyWEp8Zgz25DpL1dQ 3OCilTwpDx2a2CWgx9O9p5n733X3XpYu6hnD4VbD0qkewo+Zw1BzOFOmIpebvAA9IQux rJXXu4a3wWuyKnTsia0D0BoVq+pMEu6qGhKBqgkSkEXfzZv9F3oZmQ75xPvoPixfMBaE IbdU+qUwtbqJH8/Q2CtB9yjqRf34dHjj7zQW6W70kopkA5Wcd/pgQa/gyNUNKiCP89WP c6Ww== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=i7PLflitrAYc1ojvfYP6jnVUAWgG4SsQdyVSTkIdSQc=; b=uQij+xt6rtsoHrT+1Zod2vxBwzRpr4Rrnze3QMeVdvjsaA9TA85BBM27FOSFhTY8nJ +EzndF1HUFuebn3WwxQd7SDNx45Aiad2VgzY6ZXf6TAx+VlMg49b22mUtjKRIR089C2J ehIcQhe1Zh1n1TpN6FzLnRYNPZl4qMNXE44nH0895mRSFBaONHNaNX9uxSPNL26xKQac LDDn71jR28gqVZXWGZ63FGpx8dGaliJrq/C2DMSO+3Us3oltt2r8AUcE9wwKUmXtNbXS nZI2sZm0PKcW96cLLRktxBwleg+Ml6TuNPFCobBe+9Jvz77oz2ZCGwU+wMKRVY9S6COi F83g== X-Gm-Message-State: AOAM532sq1jQIWao6MBgmFjVFrji1zOqAzODqE9nnccei184V0o34r0b VZbD5HYM/bzVI40seIeQZfRpTWj7vbTQba8HGU6C6w== X-Received: by 2002:a05:651c:2ca:: with SMTP id f10mr31375708ljo.203.1626881826838; Wed, 21 Jul 2021 08:37:06 -0700 (PDT) MIME-Version: 1.0 References: <20210721151100.2042139-1-arnd@kernel.org> In-Reply-To: <20210721151100.2042139-1-arnd@kernel.org> From: Bailey Forrest Date: Wed, 21 Jul 2021 08:36:55 -0700 Message-ID: Subject: Re: [PATCH] gve: DQO: avoid unused variable warnings To: Arnd Bergmann Cc: Catherine Sullivan , "David S. Miller" , Jakub Kicinski , Willem de Bruijn , Arnd Bergmann , Sagi Shahar , Jon Olson , netdev@vger.kernel.org, linux-kernel@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Thanks for the patch! On Wed, Jul 21, 2021 at 8:11 AM Arnd Bergmann wrote: > > From: Arnd Bergmann > > The use of dma_unmap_addr()/dma_unmap_len() in the driver causes > multiple warnings when these macros are defined as empty: > > drivers/net/ethernet/google/gve/gve_tx_dqo.c: In function 'gve_tx_add_skb_no_copy_dqo': > drivers/net/ethernet/google/gve/gve_tx_dqo.c:494:40: error: unused variable 'buf' [-Werror=unused-variable] > 494 | struct gve_tx_dma_buf *buf = > > As it turns out, there are three copies of the same loop, > and one of them is already split out into a separate function. > > Fix the warning in this one place, and change the other two > to call it instead of open-coding the same loop. > > Fixes: a57e5de476be ("gve: DQO: Add TX path") > Signed-off-by: Arnd Bergmann > --- > The warning is present in both 5.14-rc2 and net-next as of today > --- > drivers/net/ethernet/google/gve/gve_tx_dqo.c | 92 ++++++++------------ > 1 file changed, 35 insertions(+), 57 deletions(-) > > diff --git a/drivers/net/ethernet/google/gve/gve_tx_dqo.c b/drivers/net/ethernet/google/gve/gve_tx_dqo.c > index 05ddb6a75c38..fffa882db493 100644 > --- a/drivers/net/ethernet/google/gve/gve_tx_dqo.c > +++ b/drivers/net/ethernet/google/gve/gve_tx_dqo.c > @@ -73,6 +73,26 @@ gve_free_pending_packet(struct gve_tx_ring *tx, > } > } > > +static void gve_unmap_packet(struct device *dev, > + struct gve_tx_pending_packet_dqo *pending_packet) > +{ > + dma_addr_t addr; > + size_t len; > + int i; > + > + /* SKB linear portion is guaranteed to be mapped */ > + addr = dma_unmap_addr(&pending_packet->bufs[0], dma); > + len = dma_unmap_len(&pending_packet->bufs[0], len); > + dma_unmap_single(dev, addr, len, DMA_TO_DEVICE); "SKB linear portion is guaranteed to be mapped" is only true if gve_tx_add_skb_no_copy_dqo completed successfully. This optimization is important for the success path because otherwise there would be a per-packet branch misprediction, which I found to have a large performance impact. A solution which should address this would be something like: +static void gve_unmap_packet(struct device *dev, + struct gve_tx_pending_packet_dqo *pending_packet + bool always_unmap_first) +{ + dma_addr_t addr; + size_t len; + int i; + + if (always_unmap_first || pending_packet->num_bufs > 0) { + addr = dma_unmap_addr(&pending_packet->bufs[0], dma); + len = dma_unmap_len(&pending_packet->bufs[0], len); + dma_unmap_single(dev, addr, len, DMA_TO_DEVICE); + } + + for (i = 1; i < pending_packet->num_bufs; i++) { + addr = dma_unmap_addr(&pending_packet->bufs[i], dma); + len = dma_unmap_len(&pending_packet->bufs[i], len); + dma_unmap_page(dev, addr, len, DMA_TO_DEVICE); + } + pending_packet->num_bufs = 0; +} (Sorry my email client keeps turning tabs into spaces...) By doing this, we can rely on the compiler to optimize away the extra branch in cases we know the first buffer will be mapped. > > +static inline void gve_tx_dma_buf_set(struct gve_tx_dma_buf *buf, > + dma_addr_t addr, size_t len) > +{ > + dma_unmap_len_set(buf, len, len); > + dma_unmap_addr_set(buf, dma, addr); > +} checkpatch.pl will complain about `inline` in a C file. However, I would prefer to just not introduce this helper because it introduces indirection for the reader and the risk of passing the arguments in the wrong order. Don't have a strong opinion here though.