Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp186572iog; Tue, 14 Jun 2022 23:27:35 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxMldPHMzWNkUVorKpPuYFM0mFg1889TSGeC+zMuWJ5aFKmT+8YHJNXKObKZy1tSYk/QnRI X-Received: by 2002:aa7:8094:0:b0:505:b544:d1ca with SMTP id v20-20020aa78094000000b00505b544d1camr8348114pff.26.1655274455422; Tue, 14 Jun 2022 23:27:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655274455; cv=none; d=google.com; s=arc-20160816; b=LdUj0P756XtCMwNsS0aaroKACTRNtUmoZk0VU3A8RS80wpS+fn8857Fh4j4USRWO30 0hljAHB45r3KnnjzWLKkPfxjtw5W/WHQaZCwPeK2/OHRc2fm2E8HvfD4R+oJBQNCCDT0 R+p0j7hk3DTYVG6jM7pcratkUIk+urlN+eiK0Dj5dz9YP+etyEKP3LiXfWH2MPckM2+W qNj2TC7+UPwiDA317T8FmCtNr2nGpKRFVY8E2FYvgpwye39xTOYn5/AAqGQTIoXy6YbJ xdp/YMEKmazmI84nNC4EOw97N6huXQrdeqJg2dJhhkwairtMW2YQgRt8IMqSDdkQcW8q h48w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:dkim-signature; bh=A0WUe+ant8QpycVpCnxMIq6JosP90ibIEJ2d6QtyqYw=; b=cNmvN8bupPiJ6K3HfKL0LmrfiNP6Uz1z5Edxtd1yBCF1O7+CJkjLQt5JDBogIfaUgI hdMVKuJc+g3FawKRXg2/F/iMJxLD9bF5LjtwydPW2W21Jq5yU+ZmD01MMLoRCKpkm85+ n7NpZyVpK3fdeJ0Cm3HfRLnVD0ZzsM7SVFr/5NuhJsahP//K/JGcte3A+2J+5n18DO4Y /KUCh1A4HcAuvKKY1Zcn2oWKLivmeGrJjOCHGvCJHMvAgtrmJ5MjJL79ulZQEIJI9hV5 82ILyP/Sw+iHwgRnNWowuDtHbvDQP8PQyALodacF/NdJwoAGAOKKKrZosZjL7KvdNri+ J+TQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=T+038nmK; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h18-20020a170902f55200b0015e7a2f9741si19829081plf.395.2022.06.14.23.27.20; Tue, 14 Jun 2022 23:27:35 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=T+038nmK; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1351335AbiFOGLO (ORCPT + 99 others); Wed, 15 Jun 2022 02:11:14 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58478 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1346051AbiFOGLJ (ORCPT ); Wed, 15 Jun 2022 02:11:09 -0400 Received: from mail-pj1-x102b.google.com (mail-pj1-x102b.google.com [IPv6:2607:f8b0:4864:20::102b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 85B1627CE5; Tue, 14 Jun 2022 23:11:08 -0700 (PDT) Received: by mail-pj1-x102b.google.com with SMTP id k5-20020a17090a404500b001e8875e6242so1069789pjg.5; Tue, 14 Jun 2022 23:11:08 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=A0WUe+ant8QpycVpCnxMIq6JosP90ibIEJ2d6QtyqYw=; b=T+038nmKBBf4KuTEJj/v5IT7sB1IPYgA/s9u8T4/+81XodtSAmt46Q5BL3tGHmNG9S mDPZXFcSihOzfHGqRyjvogPkrA5VFTg6QJvY6z1CXw7Wfj0eL2IHH1pS2jXBxb0taQLI fkgSTsswNiRQpD+LnKRlXhsDpbe5lc7Q22rvFQY0TNgZGiLAXetZcoKKIDJV3UCYfOs+ eCehZq6NjrI6KN0mRGQXACkv467JTG1a1V/qf4KX96AX9vlzH7iRFT6Q/7FAxgRA+4KG 3GDqW8tNtvcoII/A4UTlNIm/YicAkD74GSuucJkoObPpZcSAR7AQNWdTj6ylPuOiAaZw tZ4w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=A0WUe+ant8QpycVpCnxMIq6JosP90ibIEJ2d6QtyqYw=; b=tmk5GuZaICV+epyI7dhqcSFdgINE8kd8iVAuRHzg1eB+k8xWkFN0TgsAEq9RkElGUC 7pd1zZFsQvccTy3rLwTClJe//tF+KJjWHs2LoEQ28RDZW2BVzitSwjsHQmTxkV8HMIPZ LGJK4y8/pRvdvb8BAtf1OnChBDrx3yG1+LTLTISdMLqircmbzsB8U20GhMBHplMD7WZZ g1aQe7cCPnWG3NBnpFpbRFW0mN3sbn+OnP3+tU4IwFDy/i14pgt2uFATp74CkXfHI/yU +NJ7hJQAWH2gOxyWfr5BpCIRQj3quNw/ptEpyAMu/Ly0DFgvbcHvNxhc3CtZmhuHWtQM vocg== X-Gm-Message-State: AJIora/hkYG4fIRXtRz2pPCjoac265OuCy+05S89xnR/qBxJzBI3qAtb 8ZNJuDeu/T6EUdLUXBiafTHcdzKpSsM= X-Received: by 2002:a17:90b:3ec6:b0:1e8:a001:5c95 with SMTP id rm6-20020a17090b3ec600b001e8a0015c95mr8554338pjb.96.1655273468035; Tue, 14 Jun 2022 23:11:08 -0700 (PDT) Received: from DESKTOP-8REGVGF.localdomain ([211.25.125.254]) by smtp.gmail.com with ESMTPSA id z10-20020aa785ca000000b0051b95c76752sm8725907pfn.153.2022.06.14.23.11.05 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Jun 2022 23:11:07 -0700 (PDT) From: Sieng Piaw Liew To: davem@davemloft.net, edumazet@google.com, kuba@kernel.org, f.fainelli@gmail.com, bcm-kernel-feedback-list@broadcom.com, netdev@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Sieng Piaw Liew Subject: [PATCH V2] bcm63xx_enet: switch to napi_build_skb() to reuse skbuff_heads Date: Wed, 15 Jun 2022 14:09:22 +0800 Message-Id: <20220615060922.3402-1-liew.s.piaw@gmail.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20220614021009.696-1-liew.s.piaw@gmail.com> References: <20220614021009.696-1-liew.s.piaw@gmail.com> X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org napi_build_skb() reuses NAPI skbuff_head cache in order to save some cycles on freeing/allocating skbuff_heads on every new Rx or completed Tx. Use napi_consume_skb() to feed the cache with skbuff_heads of completed Tx so it's never empty. Signed-off-by: Sieng Piaw Liew Reviewed-by: Florian Fainelli --- drivers/net/ethernet/broadcom/bcm63xx_enet.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/net/ethernet/broadcom/bcm63xx_enet.c b/drivers/net/ethernet/broadcom/bcm63xx_enet.c index 698438a2ee0f..514d61dd91c7 100644 --- a/drivers/net/ethernet/broadcom/bcm63xx_enet.c +++ b/drivers/net/ethernet/broadcom/bcm63xx_enet.c @@ -388,7 +388,7 @@ static int bcm_enet_receive_queue(struct net_device *dev, int budget) priv->rx_buf_size, DMA_FROM_DEVICE); priv->rx_buf[desc_idx] = NULL; - skb = build_skb(buf, priv->rx_frag_size); + skb = napi_build_skb(buf, priv->rx_frag_size); if (unlikely(!skb)) { skb_free_frag(buf); dev->stats.rx_dropped++; @@ -468,7 +468,7 @@ static int bcm_enet_tx_reclaim(struct net_device *dev, int force) dev->stats.tx_errors++; bytes += skb->len; - dev_kfree_skb(skb); + napi_consume_skb(skb, !force); released++; } -- 2.17.1