Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp795245pxb; Tue, 3 Nov 2020 12:44:57 -0800 (PST) X-Google-Smtp-Source: ABdhPJy9xARzxq1YkEoPTWm/+FgfoLrv1HJtSQblQ8zWW+CvfOGHTCUAsgVU+YKGd+00t44rkTGB X-Received: by 2002:a17:906:d20a:: with SMTP id w10mr19900597ejz.3.1604436297255; Tue, 03 Nov 2020 12:44:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604436297; cv=none; d=google.com; s=arc-20160816; b=n/ApK80fY1TZ+wnMFei4sWdU8uSuQ9CRLgdHQ1kLrDXx4rxL4SV095+JPLRnE3LTVx wqIEil8tF9dhXcgjYtMGwqbnw6zX78XRCkoCMbSqWrhDhTkZPx2mYGzlvhOhgA1R21hz ohpiT1duSbcXkF1HkGUZQscNW6RtJKIRBBNdfZs7cqaK78KZxrUKtFD0oAb+ZWgy8oX3 k0L8+vLDIluagol4SKBQyLUyjNCuwRfGPAWBnP2SuHVMKpxeXv/j0eUH9zlER3lr4gSW IvlBrEHGFGMEs9CKxDIr6YLsGOJIldauim3spCV0BQEhekfWsayJ8h75yjWClisFPYdD CtyQ== 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=tSSa+CFGw0zLRvHPk+8N+nihS2+a4EH0peM53wuIJdw=; b=XX6OhBgEocvHh6FT6tz+L1NANP7snlDZbNvq6maE0UVoTbAZQJY3980PvcOot/Wyde CsfOxUyjZoXxAIR4D3en+bG6UFMrhvnPC9jcj8WGOjyP/PAp7psMwwvzt/Zs0Zsz4UlL l8HKHckGes/NzQEkaHf6uOo9yjY5eHsy/tIFXKqbfT68HrAoZGE7g1d72Mo6CnlxOomb A4mticmlltmRGoQ5e2L00ENNvNJjQF5QkpmR3ZPQ5bRv/E7ZszE+rkPmvttps6ktot98 ucFt6lH6zAiGo+CaneI1TS9UpjnRdD9D1KKlBKLzxFh6aes48/RSa01I4rwFfGPC3Mmd MNNg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=2fJKnIpK; 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=fail (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 o7si1681ejb.91.2020.11.03.12.44.32; Tue, 03 Nov 2020 12:44:57 -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=@kernel.org header.s=default header.b=2fJKnIpK; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730449AbgKCUl6 (ORCPT + 99 others); Tue, 3 Nov 2020 15:41:58 -0500 Received: from mail.kernel.org ([198.145.29.99]:53822 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730423AbgKCUlw (ORCPT ); Tue, 3 Nov 2020 15:41:52 -0500 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id E17FB2224E; Tue, 3 Nov 2020 20:41:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1604436112; bh=yir11J9qu9bPoOH46GfMgIzLbn7Qj9exDwBC6wBaBmM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=2fJKnIpKUO+7ZavarXmfaO3lPqxCbVrQFjVlRQsaY5fLT5UlIM3TXQg+1FG8ZcbQs lSEwRXOL3yFX2MAl1SXiMpY7qcCooez1kk61OrkbyLH0U4vjcQaWoW3OyYoeodPTvn VBC2Ji6fvxPH2LeGvvob4e2uhbY3pYZy9vvMoesU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Magnus Karlsson , Alexei Starovoitov , Sasha Levin Subject: [PATCH 5.9 109/391] samples/bpf: Fix possible deadlock in xdpsock Date: Tue, 3 Nov 2020 21:32:40 +0100 Message-Id: <20201103203354.175005339@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201103203348.153465465@linuxfoundation.org> References: <20201103203348.153465465@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: Magnus Karlsson [ Upstream commit 5a2a0dd88f0f267ac5953acd81050ae43a82201f ] Fix a possible deadlock in the l2fwd application in xdpsock that can occur when there is no space in the Tx ring. There are two ways to get the kernel to consume entries in the Tx ring: calling sendto() to make it send packets and freeing entries from the completion ring, as the kernel will not send a packet if there is no space for it to add a completion entry in the completion ring. The Tx loop in l2fwd only used to call sendto(). This patches adds cleaning the completion ring in that loop. Signed-off-by: Magnus Karlsson Signed-off-by: Alexei Starovoitov Link: https://lore.kernel.org/bpf/1599726666-8431-3-git-send-email-magnus.karlsson@gmail.com Signed-off-by: Sasha Levin --- samples/bpf/xdpsock_user.c | 1 + 1 file changed, 1 insertion(+) diff --git a/samples/bpf/xdpsock_user.c b/samples/bpf/xdpsock_user.c index c821e98671393..63a9a2a39da7b 100644 --- a/samples/bpf/xdpsock_user.c +++ b/samples/bpf/xdpsock_user.c @@ -1111,6 +1111,7 @@ static void l2fwd(struct xsk_socket_info *xsk, struct pollfd *fds) while (ret != rcvd) { if (ret < 0) exit_with_error(-ret); + complete_tx_l2fwd(xsk, fds); if (xsk_ring_prod__needs_wakeup(&xsk->tx)) kick_tx(xsk); ret = xsk_ring_prod__reserve(&xsk->tx, rcvd, &idx_tx); -- 2.27.0