Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1975582pxb; Fri, 5 Mar 2021 04:34:12 -0800 (PST) X-Google-Smtp-Source: ABdhPJxeeWLGEbYDocnA9saOoWNlxz2+PZsRukZqqAxRXFcUO5zLBJcwNnDjNLMxbCTiLJyFbSyd X-Received: by 2002:aa7:cc8b:: with SMTP id p11mr9016829edt.284.1614947652415; Fri, 05 Mar 2021 04:34:12 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614947652; cv=none; d=google.com; s=arc-20160816; b=GohrSs8XsenqwCRaUllD7mnAJCHc/W6pvFatCx7iO+1sDshkQCSgPc9RtjgfubD6+B aoiAmhlYBcTBYI9L3SqqViGcf+XtOHVfwGLv5YNMRZIxyYLOipdE3z820U3DVTEBqrCR Q5QYYuIiwhqfu+fxeVvwX906dV7l35tXz7d4kkJpshrVKi95TvTalwZwkEUBt9e2Rx8Q inXo9Oc4uDOxlVdB+hH6cWCyNE6Y+z+ttj4oR4MY5oEDrgbJt7NeFf/4O6xNWDy/TAUb P+q6+YEZ43jm3OxSRQQsqlkWCnu2+COco3slavv37vuY4tCFZ/8hVIOkeyDTubIdHrKK RONQ== 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=puRsHYRxCRAhg4BM//Fri1FjscMARiDj3Zdjt54hRFU=; b=z9WXpMMzyLzJCYk3AgdtFCG+dXdQtY5f9XO9h3etKtrja4EnAZ5mGSW85FZBvkilxx A3aRmjKFR0wCPVsX7i5lXWLEdmSZNylNZK1v7ft7jyzCy++tJQJ4w5vsNyf6AdU8vhXE IOd/zXyXHaPzzFZ+MAAaPlOESHrLAy9hH5uKw1i0wIrWFKF5AMck4WgWmWgkY4o6T4zG rqs8ZxhruNkP+8O0fobNXDJrsxFO5RNELzyyWO1ViwbJzeNTaed9kSLj0XBW1veFpBt2 v64a2ElJrIlTTlLWRWudgAiL5B3nH7qY0+Jkikka7VnZT5v9Gs9PDFGoCjeBSKdQPkW5 A0qA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=DQKS21Qy; 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=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 y16si1452803edi.542.2021.03.05.04.33.48; Fri, 05 Mar 2021 04:34:12 -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=@linuxfoundation.org header.s=korg header.b=DQKS21Qy; 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=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232328AbhCEMcv (ORCPT + 99 others); Fri, 5 Mar 2021 07:32:51 -0500 Received: from mail.kernel.org ([198.145.29.99]:42352 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232661AbhCEMcJ (ORCPT ); Fri, 5 Mar 2021 07:32:09 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 51B926501A; Fri, 5 Mar 2021 12:32:08 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1614947528; bh=CdyjO0DzAQYcvYBXpXgGcTDehYI93C8q/0VzfnTXLR0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=DQKS21QyqPRstfONgCXGrk6aQWPpIOd0xA6IbP/yiC0lfRpafGnWWPVaTm2LrNXLy yeJS+TgldQyyBd+2yr2bhGIUozNb3dIIflPK1jKbipnx6QPLWvxqFTaXELuGi1P/QK qMXHkip8BqwMEGDGMwCGHVtI21OdShzhg+WqD/fE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jiri Slaby , Linus Torvalds Subject: [PATCH 5.10 095/102] tty: fix up hung_up_tty_read() conversion Date: Fri, 5 Mar 2021 13:21:54 +0100 Message-Id: <20210305120907.951364140@linuxfoundation.org> X-Mailer: git-send-email 2.30.1 In-Reply-To: <20210305120903.276489876@linuxfoundation.org> References: <20210305120903.276489876@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: Linus Torvalds commit ddc5fda7456178e2cbc87675b370920d98360daf upstream. In commit "tty: implement read_iter", I left the read_iter conversion of the hung up tty case alone, because I incorrectly thought it didn't matter. Jiri showed me the errors of my ways, and pointed out the problems with that incomplete conversion. Fix it all up. Reported-by: Jiri Slaby Signed-off-by: Linus Torvalds Reviewed-by: Jiri Slaby Link: https://lore.kernel.org/r/CAHk-=wh+-rGsa=xruEWdg_fJViFG8rN9bpLrfLz=_yBYh2tBhA@mail.gmail.com Signed-off-by: Greg Kroah-Hartman --- drivers/tty/tty_io.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) --- a/drivers/tty/tty_io.c +++ b/drivers/tty/tty_io.c @@ -429,8 +429,7 @@ struct tty_driver *tty_find_polling_driv EXPORT_SYMBOL_GPL(tty_find_polling_driver); #endif -static ssize_t hung_up_tty_read(struct file *file, char __user *buf, - size_t count, loff_t *ppos) +static ssize_t hung_up_tty_read(struct kiocb *iocb, struct iov_iter *to) { return 0; } @@ -502,7 +501,7 @@ static const struct file_operations cons static const struct file_operations hung_up_tty_fops = { .llseek = no_llseek, - .read = hung_up_tty_read, + .read_iter = hung_up_tty_read, .write_iter = hung_up_tty_write, .poll = hung_up_tty_poll, .unlocked_ioctl = hung_up_tty_ioctl, @@ -929,8 +928,10 @@ static ssize_t tty_read(struct kiocb *io /* We want to wait for the line discipline to sort out in this situation */ ld = tty_ldisc_ref_wait(tty); + if (!ld) + return hung_up_tty_read(iocb, to); i = -EIO; - if (ld && ld->ops->read) + if (ld->ops->read) i = iterate_tty_read(ld, tty, file, to); tty_ldisc_deref(ld);