Received: by 2002:a25:e7d8:0:0:0:0:0 with SMTP id e207csp678485ybh; Tue, 10 Mar 2020 06:20:13 -0700 (PDT) X-Google-Smtp-Source: ADFU+vvsl19ALyIU+HHLK8LDg6IzbrFefOGoqh/f4hzUdh0eJf+XBL0AB97GR6NcC+2im4NmrxZ4 X-Received: by 2002:a9d:6a9a:: with SMTP id l26mr17458190otq.104.1583846412934; Tue, 10 Mar 2020 06:20:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1583846412; cv=none; d=google.com; s=arc-20160816; b=UQP0mO3tVEY1+t15NHgfjRwNRjsSctzVJ4gtkIQkugotu1dr9zzQDRCTuQ8hAT/khx iwQsv8lJK6kXkJtehUmzEqtn7s0O/OUidsONgVW40EggIAqUlxcKIlaSf4b2hKdYobqK WM+sfbhV0pmnhfnUcSLMj7FNLnGwz6DGP9D4pKSaO1oD0uBzC0OZbAQigX2RWsTlRIrF lIj/vqATn+9jpLul/bD00ADwYf/HIaCHtEfVfbm3Np9I6VibMoycbUQIlSBvEevwvJtc JPPkOn4H8OS4XUm5XD8vP+Qn2CCE4jpQtZaGQL06TgC2+tqA+h6hinbtZqyVR/wO8x9M L++Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=WVNEWOfv6gIf9VKAQk23V/jallTPul4punbbHqFsOpQ=; b=Qxg0aXlanOb0hYcTQ31VVgVjYUzj/vxueGplmW5tImSB1exJi2WdDjgroPzHhT0epk ISKOsmvPfP+BDP0IOuWJIQu8Da5hpTechnRAlgJwAUq5ud6HU62RNC3t4FotY3v6B7OD 2Iq+vR5bETuJPpgrKulQBT8USAnIF6ib+jtEQFZLWlm9rzR6SJNZRiyqV5JyM1zXDz4Z 8S36yFcFekx5ecK+UKYZJRjthkqaZ1ZNsSiybvfcBP3EL9BVsJt9oM8q8erM8axVnSrg uKV65WHe8TAcQiWWbBOB+/cQwYKdJGEATjuP95m7bw1CuOwM1wFUO2cT5CDuxaMp1F6y nN2Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=ndRsMaqI; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m126si4853705oig.177.2020.03.10.06.20.01; Tue, 10 Mar 2020 06:20:12 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=ndRsMaqI; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731260AbgCJNJn (ORCPT + 99 others); Tue, 10 Mar 2020 09:09:43 -0400 Received: from mail.kernel.org ([198.145.29.99]:56914 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731256AbgCJNJm (ORCPT ); Tue, 10 Mar 2020 09:09:42 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (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 1B5EF20873; Tue, 10 Mar 2020 13:09:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1583845781; bh=hP7QB49/EqfVLxCeySXGAPy+WtwNAdFQlnAJKdDcWTc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ndRsMaqII4iENyzZEGPxppW/sjOCBfjZ+GfDOUkAN+teFfsW2qjiDexlnI+rXwl4l Unxx//BXyMa7DFl3iRujDgGX4wr/r6iETPo90CyTWpHJiBHH1UwUTYwYeCNieLzI34 Bw+nVGOgTiscoGTXcnkqhdm2q/X1LoeTylunZxoo= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Hannes Frederic Sowa , Eric Dumazet , Jason Wang , "David S. Miller" , Tommi Rantala Subject: [PATCH 4.14 059/126] tuntap: correctly set SOCKWQ_ASYNC_NOSPACE Date: Tue, 10 Mar 2020 13:41:20 +0100 Message-Id: <20200310124207.925139999@linuxfoundation.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200310124203.704193207@linuxfoundation.org> References: <20200310124203.704193207@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jason Wang commit 2f3ab6221e4c87960347d65c7cab9bd917d1f637 upstream. When link is down, writes to the device might fail with -EIO. Userspace needs an indication when the status is resolved. As a fix, tun_net_open() attempts to wake up writers - but that is only effective if SOCKWQ_ASYNC_NOSPACE has been set in the past. This is not the case of vhost_net which only poll for EPOLLOUT after it meets errors during sendmsg(). This patch fixes this by making sure SOCKWQ_ASYNC_NOSPACE is set when socket is not writable or device is down to guarantee EPOLLOUT will be raised in either tun_chr_poll() or tun_sock_write_space() after device is up. Cc: Hannes Frederic Sowa Cc: Eric Dumazet Fixes: 1bd4978a88ac2 ("tun: honor IFF_UP in tun_get_user()") Signed-off-by: Jason Wang Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman Signed-off-by: Tommi Rantala --- drivers/net/tun.c | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) --- a/drivers/net/tun.c +++ b/drivers/net/tun.c @@ -1134,6 +1134,13 @@ static void tun_net_init(struct net_devi dev->max_mtu = MAX_MTU - dev->hard_header_len; } +static bool tun_sock_writeable(struct tun_struct *tun, struct tun_file *tfile) +{ + struct sock *sk = tfile->socket.sk; + + return (tun->dev->flags & IFF_UP) && sock_writeable(sk); +} + /* Character device part */ /* Poll */ @@ -1156,10 +1163,14 @@ static unsigned int tun_chr_poll(struct if (!skb_array_empty(&tfile->tx_array)) mask |= POLLIN | POLLRDNORM; - if (tun->dev->flags & IFF_UP && - (sock_writeable(sk) || - (!test_and_set_bit(SOCKWQ_ASYNC_NOSPACE, &sk->sk_socket->flags) && - sock_writeable(sk)))) + /* Make sure SOCKWQ_ASYNC_NOSPACE is set if not writable to + * guarantee EPOLLOUT to be raised by either here or + * tun_sock_write_space(). Then process could get notification + * after it writes to a down device and meets -EIO. + */ + if (tun_sock_writeable(tun, tfile) || + (!test_and_set_bit(SOCKWQ_ASYNC_NOSPACE, &sk->sk_socket->flags) && + tun_sock_writeable(tun, tfile))) mask |= POLLOUT | POLLWRNORM; if (tun->dev->reg_state != NETREG_REGISTERED)