Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp4544132pxb; Wed, 20 Apr 2022 05:32:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy3XrknNoiD97Iqd+T7I3UDqzurlJuG+D923c20MIa2Fba04r+YekLnQCQfMMmRZQYPq17R X-Received: by 2002:a17:906:dc8a:b0:6e0:94bf:1ec3 with SMTP id cs10-20020a170906dc8a00b006e094bf1ec3mr17736424ejc.447.1650457950502; Wed, 20 Apr 2022 05:32:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650457950; cv=none; d=google.com; s=arc-20160816; b=MdEGW1Yl6GpI1O1c0OqaLHLakpAR7wj2I+aCkE6mpkBm0G8OhGreWQ6BvvUglYP/lv HAM+gFLSH9d3OB2Qf9MzPaRHqW3HtB7AO7tZeQudRA5sSgpv2WKVm7hTJ56SQNBWZ8li 0vKjCv1SzVzHZ1Wme0YrDiT9jubFYTHh3TEGUqU6x31Dp4spXf1bfog9+nAeC1M2p4zq htzvSuEzajOEyX2XZnbIYSO8GdnTdcn+KXPMdOD05N7W1t5MSyhRU3LNIuPfMhPAqN/t QTbNt6+G6+O3rD1N7LMfKADerszcaHzBHWWUT0+1fnMa00UataVcTPN9BAcKHQ27tXRr C8KQ== 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=6RZt3pRY2aKwzYWHycI06GL3k6VJx2KQpfieK912YU8=; b=VPny/rDlPUC5yadfncm9Xpiheg4jn462Nyh3sByfAoX4qa8Sj9AinMmCy46Q5WJSwQ zZwX67UN5Du4lZaUvUkvRDpHtNZ8x1G3R2/Q3gggMF2Nc94g/9dDKC+vOGvih54gBr5N QyotpN76fUjU/0FlaPJ44Kyfa7pRBttNm6qG4Dz8giU7EYDOGbKCNpExS6nITQ6J4MZz dbRIQCbq8ItszaK/od8hO0QcraFakWLXV3dQaQcXUBdx9ApxnGim8VV8SL8qrcViX2q0 EfB1NjWFUT0PDmtf/YrnU8yojil3An9rwevBZV7iPjw1Y5VY2uItMWWjtKu1jgyR6KvP bL7A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=B+cxRY9F; 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 u10-20020a50950a000000b0041d7dba939asi1295892eda.170.2022.04.20.05.32.05; Wed, 20 Apr 2022 05:32:30 -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=B+cxRY9F; 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 S1358719AbiDTBaf (ORCPT + 99 others); Tue, 19 Apr 2022 21:30:35 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33538 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232010AbiDTBae (ORCPT ); Tue, 19 Apr 2022 21:30:34 -0400 Received: from mail-oi1-x22a.google.com (mail-oi1-x22a.google.com [IPv6:2607:f8b0:4864:20::22a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B350524969; Tue, 19 Apr 2022 18:27:49 -0700 (PDT) Received: by mail-oi1-x22a.google.com with SMTP id 12so459220oix.12; Tue, 19 Apr 2022 18:27:49 -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=6RZt3pRY2aKwzYWHycI06GL3k6VJx2KQpfieK912YU8=; b=B+cxRY9FhW3qdrJo5zcX6sM27c423HY/NsSxFAgyuclMXAJFwQK1KTll69IMEU19Su 20uLodQmfsoLbbRgBO1oFs/wUrRP13lxDSZSt44zqP8G+DteCzjY0ybV5oJgRQL3bgaW oL6afyZgrOEIVVpilc7VdFeRUhRpflx2IH60v0ZaFqjpnzYT4zDNijDaJErUFQR3NdN3 rSgBxlNvI0tjgjQb65SZ8gtcqqOyhcT7dUYuSC2fuR8ciQ33E+K2Lbkkd+1+Ew5YtMkM RIw5Z/8GN7/6BzNwJl+EVKneuM2X8FAhSR1jNV6DD1h4OMfBD8bg48zfUH9Vn6N3xFid hUVg== 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=6RZt3pRY2aKwzYWHycI06GL3k6VJx2KQpfieK912YU8=; b=0Xdv3h6/I2JlQzxJvtEDT8nZ0lgU9D+SeiHW1hIXEl9e6gulDeG6ew+MgA1RThWvUr BDPB7w662WB1uWpbQKfz5xEG0Jq9Uv27btonTvf0GFuoEpXjQiKcex+ToMDOgKIp9GTY wTGPuaz9S+1drFyEbIFVu/TkQ0J/hMFZK/rr3u4pdfmDu3UU8vPbfWxN7WM6uUodSQHO 5pFuUMhs1YHJ5ZzdihJzAFDyuO29oDMzd5lNlMYh+UObtbaljrSeHY8IQaxrfDZ5uF0u 9efDr1kFh5DYWUV6gQpSzTg2P1VByCxOS0g1984Y6Df9FB2+4XSKaVKUKzMOnlAirOWd h4Dw== X-Gm-Message-State: AOAM530gyR3gVIqQTVCrSX8iVTyydSn+dLtiCslZPegvrk7pxS6OeiqH k8AjWFFP3EXYx8rEMpZXzPWHvIrkttpmWgLi X-Received: by 2002:aca:d9c3:0:b0:2fa:6f51:7bfe with SMTP id q186-20020acad9c3000000b002fa6f517bfemr639590oig.59.1650418069051; Tue, 19 Apr 2022 18:27:49 -0700 (PDT) Received: from toe.qscaudio.com ([65.113.122.35]) by smtp.gmail.com with ESMTPSA id i26-20020a4a929a000000b0033a29c8d564sm4284530ooh.3.2022.04.19.18.27.48 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 19 Apr 2022 18:27:48 -0700 (PDT) From: jeff.evanson@gmail.com X-Google-Original-From: jeff.evanson@qsc.com To: Jesse Brandeburg , Tony Nguyen , "David S. Miller" , Jakub Kicinski , Alexei Starovoitov , Daniel Borkmann , Jesper Dangaard Brouer , John Fastabend , Vedang Patel , Andre Guedes , Maciej Fijalkowski , Jithu Joseph , intel-wired-lan@lists.osuosl.org (moderated list:INTEL ETHERNET DRIVERS), netdev@vger.kernel.org (open list:NETWORKING DRIVERS), linux-kernel@vger.kernel.org (open list), bpf@vger.kernel.org (open list:XDP (eXpress Data Path)) Cc: Jeff Evanson Subject: [PATCH v2 1/2] igc: Fix race in igc_xdp_xmit_zc Date: Tue, 19 Apr 2022 19:26:34 -0600 Message-Id: <20220420012635.13733-2-jeff.evanson@qsc.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20220420012635.13733-1-jeff.evanson@qsc.com> References: <20220420012635.13733-1-jeff.evanson@qsc.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 From: Jeff Evanson In igc_xdp_xmit_zc, initialize next_to_use while holding the netif_tx_lock to prevent racing with other users of the tx ring. Fixes: 9acf59a752d4 (igc: Enable TX via AF_XDP zero-copy) --- drivers/net/ethernet/intel/igc/igc_main.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/net/ethernet/intel/igc/igc_main.c b/drivers/net/ethernet/intel/igc/igc_main.c index 1c00ee310c19..a36a18c84aeb 100644 --- a/drivers/net/ethernet/intel/igc/igc_main.c +++ b/drivers/net/ethernet/intel/igc/igc_main.c @@ -2598,7 +2598,7 @@ static void igc_xdp_xmit_zc(struct igc_ring *ring) struct netdev_queue *nq = txring_txq(ring); union igc_adv_tx_desc *tx_desc = NULL; int cpu = smp_processor_id(); - u16 ntu = ring->next_to_use; + u16 ntu; struct xdp_desc xdp_desc; u16 budget; @@ -2607,6 +2607,8 @@ static void igc_xdp_xmit_zc(struct igc_ring *ring) __netif_tx_lock(nq, cpu); + ntu = ring->next_to_use; + budget = igc_desc_unused(ring); while (xsk_tx_peek_desc(pool, &xdp_desc) && budget--) { -- 2.17.1