Received: by 2002:a05:6358:1087:b0:cb:c9d3:cd90 with SMTP id j7csp4901200rwi; Mon, 17 Oct 2022 12:21:48 -0700 (PDT) X-Google-Smtp-Source: AMsMyM6D4MydtqgR0VJcLls3R4oyaQiftfpMfPmjuXFR3QpjBCAUStF0Rs5ulRCSr1ks07hTWuQR X-Received: by 2002:a17:902:cf03:b0:17e:c7a:678e with SMTP id i3-20020a170902cf0300b0017e0c7a678emr13246322plg.10.1666034507924; Mon, 17 Oct 2022 12:21:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1666034507; cv=none; d=google.com; s=arc-20160816; b=O4bVZGN9k/Sd/POGSP5AkCkf1GqObRNUn8a/a8ybHY+aPezg3Rr59sNGrnJPvCsTzm ceOLGsMxJB0amrZBseIbzQCKBtZMdUIja1B3O34QeZNFs1hK8NAMeZpKnS9kHVHqWawf /GqG9wExLyIa7VKqnmtD9eODJgL64HPr1qv2/sN81KB7Z6M127GBGa+LgTOQsWWjP6zN yIijrgj33cK0R4ZbDtnRcyudIGlS0B0jyV/nlARoTXabIY3rqYc71nvFDlpNggmO5fVi YQEL3GZBzIQfkc7+cmql6a6Di8fcGD0KGvHbSRnGQcoJ7gT68Jax1yqbpv8pFK35zJI3 Dr/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:to:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:from :dkim-signature; bh=3l6Jm/j5UGLMxQsiYqUPn8xoi5WXHOYfNbpCDtSFPMI=; b=iOSc/Iq0Rf64hHVEAF30gmPqFPfiTK/6KxT8HG5rMRwyOv2Pe8VM8fUM7jUnv57Gsi chEd4pMBBVMMMng63Vu7Q3mBaPdd/NCSW7h5N6dmWkx0iwPdizYAzRQqJCVAcoGZDkJE 8LbKw72omhsDP5qHtgU4sg8PAiRFP3AWSv3hsQfcwNkGRs+6HvTPDv7/4z2auSGsnMqg joMm3duxM3Tk+zJ5zSsImwPEgAAaX+XbewX55uL2YSP+ZwejGyVMwHfPqS8v3f0UWiuO ZQ2XlfRp5Yl9VzsexibDR5r9Ci0hqnCFp7xSKgnBraLEuzNyvdIcp9/DMWaPQfKEETZX 51pA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@oracle.com header.s=corp-2022-7-12 header.b=1zMdrNYk; 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=fail (p=NONE sp=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b8-20020a056a000a8800b0053e2be48c98si13218859pfl.76.2022.10.17.12.21.35; Mon, 17 Oct 2022 12:21:47 -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=fail header.i=@oracle.com header.s=corp-2022-7-12 header.b=1zMdrNYk; 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=fail (p=NONE sp=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230209AbiJQTUs (ORCPT + 99 others); Mon, 17 Oct 2022 15:20:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55282 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230431AbiJQTUj (ORCPT ); Mon, 17 Oct 2022 15:20:39 -0400 Received: from mx0b-00069f02.pphosted.com (mx0b-00069f02.pphosted.com [205.220.177.32]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 861277674E; Mon, 17 Oct 2022 12:20:36 -0700 (PDT) Received: from pps.filterd (m0246630.ppops.net [127.0.0.1]) by mx0b-00069f02.pphosted.com (8.17.1.5/8.17.1.5) with ESMTP id 29HITJ4J026745; Mon, 17 Oct 2022 19:20:35 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=from : to : cc : subject : date : message-id : in-reply-to : references : mime-version : content-transfer-encoding; s=corp-2022-7-12; bh=3l6Jm/j5UGLMxQsiYqUPn8xoi5WXHOYfNbpCDtSFPMI=; b=1zMdrNYksEDo7ORUz3SeEO3Z/w5pDWTSJUGZ3Qk2m93r7yNI7Ff6x3axRI7Ry9KSb3CP Z+YipYNuUS7cbBQWYxvc96JysTYQNV6hbtxhMh50ZjEtRi44lV+JVilbtBUkpjBpTshO RPGjkDaWJsm7kGPTsDA0fvsoNAK5NkrX2x3IxlceFkN1LVo/AiLPD56gUYd6y9sEzBjh q0/hFJh1I+6XtaL1TzXkL1hn2KqQQJay2O7vXLECGPhhS1FFpCEsntbEDIZNAk7VOL5p nthtmutVzAbVDZA/tyPCK6xauW24q23UAgZiNeuFGeySS+ONHtTCpqurU0huTeQ0QHP6 Cw== Received: from iadpaimrmta02.imrmtpd1.prodappiadaev1.oraclevcn.com (iadpaimrmta02.appoci.oracle.com [147.154.18.20]) by mx0b-00069f02.pphosted.com (PPS) with ESMTPS id 3k9b7sga5a-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Mon, 17 Oct 2022 19:20:35 +0000 Received: from pps.filterd (iadpaimrmta02.imrmtpd1.prodappiadaev1.oraclevcn.com [127.0.0.1]) by iadpaimrmta02.imrmtpd1.prodappiadaev1.oraclevcn.com (8.17.1.5/8.17.1.5) with ESMTP id 29HHae95036317; Mon, 17 Oct 2022 19:20:34 GMT Received: from pps.reinject (localhost [127.0.0.1]) by iadpaimrmta02.imrmtpd1.prodappiadaev1.oraclevcn.com (PPS) with ESMTPS id 3k8htf4avv-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Mon, 17 Oct 2022 19:20:34 +0000 Received: from iadpaimrmta02.imrmtpd1.prodappiadaev1.oraclevcn.com (iadpaimrmta02.imrmtpd1.prodappiadaev1.oraclevcn.com [127.0.0.1]) by pps.reinject (8.17.1.5/8.17.1.5) with ESMTP id 29HJKCYr007860; Mon, 17 Oct 2022 19:20:34 GMT Received: from ca-dev112.us.oracle.com (ca-dev112.us.oracle.com [10.147.25.63]) by iadpaimrmta02.imrmtpd1.prodappiadaev1.oraclevcn.com (PPS) with ESMTP id 3k8htf4abs-3; Mon, 17 Oct 2022 19:20:33 +0000 From: Saeed Mirzamohammadi Cc: linux-fsdevel@vger.kernel.org, viro@zeniv.linux.org.uk, linux-kernel@vger.kernel.org, stable@vger.kernel.org, jason@zx2c4.com, saeed.mirzamohammadi@oracle.com, "Jason A. Donenfeld" Subject: [PATCH stable 2/5] fs: do not compare against ->llseek Date: Mon, 17 Oct 2022 12:20:03 -0700 Message-Id: <20221017192006.36398-3-saeed.mirzamohammadi@oracle.com> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20221017192006.36398-1-saeed.mirzamohammadi@oracle.com> References: <20221017192006.36398-1-saeed.mirzamohammadi@oracle.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.205,Aquarius:18.0.895,Hydra:6.0.545,FMLib:17.11.122.1 definitions=2022-10-17_13,2022-10-17_02,2022-06-22_01 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 mlxlogscore=999 phishscore=0 suspectscore=0 spamscore=0 adultscore=0 mlxscore=0 malwarescore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2209130000 definitions=main-2210170111 X-Proofpoint-GUID: MHRi98lwiCqt0TgbuOmYkPTCCLszGlZv X-Proofpoint-ORIG-GUID: MHRi98lwiCqt0TgbuOmYkPTCCLszGlZv X-Spam-Status: No, score=-2.8 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_LOW, RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net To: unlisted-recipients:; (no To-header on input) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: "Jason A. Donenfeld" Now vfs_llseek() can simply check for FMODE_LSEEK; if it's set, we know that ->llseek() won't be NULL and if it's not we should just fail with -ESPIPE. A couple of other places where we used to check for special values of ->llseek() (somewhat inconsistently) switched to checking FMODE_LSEEK. Signed-off-by: Jason A. Donenfeld Signed-off-by: Al Viro (cherry picked from commit 4e3299eaddffd9d7d5b8bae28ad700bb775f02d0) Cc: stable@vger.kernel.org Signed-off-by: Saeed Mirzamohammadi --- fs/coredump.c | 4 ++-- fs/overlayfs/copy_up.c | 3 +-- fs/read_write.c | 11 +++-------- 3 files changed, 6 insertions(+), 12 deletions(-) diff --git a/fs/coredump.c b/fs/coredump.c index 26eb5a095832..04ce02e30e23 100644 --- a/fs/coredump.c +++ b/fs/coredump.c @@ -886,9 +886,9 @@ static int __dump_skip(struct coredump_params *cprm, size_t nr) { static char zeroes[PAGE_SIZE]; struct file *file = cprm->file; - if (file->f_op->llseek && file->f_op->llseek != no_llseek) { + if (file->f_mode & FMODE_LSEEK) { if (dump_interrupted() || - file->f_op->llseek(file, nr, SEEK_CUR) < 0) + vfs_llseek(file, nr, SEEK_CUR) < 0) return 0; cprm->pos += nr; return 1; diff --git a/fs/overlayfs/copy_up.c b/fs/overlayfs/copy_up.c index e040970408d4..7636ec4d8b1c 100644 --- a/fs/overlayfs/copy_up.c +++ b/fs/overlayfs/copy_up.c @@ -226,8 +226,7 @@ static int ovl_copy_up_data(struct ovl_fs *ofs, struct path *old, /* Couldn't clone, so now we try to copy the data */ /* Check if lower fs supports seek operation */ - if (old_file->f_mode & FMODE_LSEEK && - old_file->f_op->llseek) + if (old_file->f_mode & FMODE_LSEEK) skip_hole = true; while (len) { diff --git a/fs/read_write.c b/fs/read_write.c index 8d3ec975514d..b64527211b32 100644 --- a/fs/read_write.c +++ b/fs/read_write.c @@ -290,14 +290,9 @@ EXPORT_SYMBOL(default_llseek); loff_t vfs_llseek(struct file *file, loff_t offset, int whence) { - loff_t (*fn)(struct file *, loff_t, int); - - fn = no_llseek; - if (file->f_mode & FMODE_LSEEK) { - if (file->f_op->llseek) - fn = file->f_op->llseek; - } - return fn(file, offset, whence); + if (!(file->f_mode & FMODE_LSEEK)) + return -ESPIPE; + return file->f_op->llseek(file, offset, whence); } EXPORT_SYMBOL(vfs_llseek); -- 2.31.1