From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-0.8 required=3.0 tests=BAYES_40, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS, URIBL_BLOCKED autolearn=no autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 8A9EDC433E0 for ; Mon, 11 Jan 2021 14:44:32 +0000 (UTC) Received: from ml01.01.org (ml01.01.org [198.145.21.10]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id A32E9221F9 for ; Mon, 11 Jan 2021 14:44:31 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org A32E9221F9 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=zeniv.linux.org.uk Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-nvdimm-bounces@lists.01.org Received: from ml01.vlan13.01.org (localhost [IPv6:::1]) by ml01.01.org (Postfix) with ESMTP id 29949100EBBA0; Mon, 11 Jan 2021 06:44:31 -0800 (PST) Received-SPF: None (mailfrom) identity=mailfrom; client-ip=2002:c35c:fd02::1; helo=zeniv.linux.org.uk; envelope-from=viro@ftp.linux.org.uk; receiver= Received: from ZenIV.linux.org.uk (zeniv.linux.org.uk [IPv6:2002:c35c:fd02::1]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) (No client certificate requested) by ml01.01.org (Postfix) with ESMTPS id 7167C100ED498 for ; Mon, 11 Jan 2021 06:44:28 -0800 (PST) Received: from viro by ZenIV.linux.org.uk with local (Exim 4.92.3 #3 (Red Hat Linux)) id 1kyyQ1-009I2g-Bx; Mon, 11 Jan 2021 14:43:41 +0000 Date: Mon, 11 Jan 2021 14:43:41 +0000 From: Al Viro To: David Laight Subject: Re: [RFC v2] nvfs: a filesystem for persistent memory Message-ID: <20210111144341.GZ3579531@ZenIV.linux.org.uk> References: <20210110162008.GV3579531@ZenIV.linux.org.uk> <57dad96341d34822a7943242c9bcad71@AcuMS.aculab.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <57dad96341d34822a7943242c9bcad71@AcuMS.aculab.com> Sender: Al Viro Message-ID-Hash: XKAJ5ZWGBCKAMQ7OSHRYIUUWAXBCB2T2 X-Message-ID-Hash: XKAJ5ZWGBCKAMQ7OSHRYIUUWAXBCB2T2 X-MailFrom: viro@ftp.linux.org.uk X-Mailman-Rule-Hits: nonmember-moderation X-Mailman-Rule-Misses: dmarc-mitigation; no-senders; approved; emergency; loop; banned-address; member-moderation CC: 'Mikulas Patocka' , Andrew Morton , Matthew Wilcox , Jan Kara , Steven Whitehouse , Eric Sandeen , Dave Chinner , Theodore Ts'o , Wang Jianchao , "Tadakamadla, Rajesh" , "linux-kernel@vger.kernel.org" , "linux-fsdevel@vger.kernel.org" , "linux-nvdimm@lists.01.org" X-Mailman-Version: 3.1.1 Precedence: list List-Id: "Linux-nvdimm developer list." Archived-At: List-Archive: List-Help: List-Post: List-Subscribe: List-Unsubscribe: Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit On Mon, Jan 11, 2021 at 11:57:08AM +0000, David Laight wrote: > > > > size = copy_to_iter(to, ptr, size); > > > > if (unlikely(!size)) { > > > > r = -EFAULT; > > > > goto ret_r; > > > > } > > > > > > > > pos += size; > > > > total += size; > > > > } while (iov_iter_count(to)); > > > > > > That isn't the best formed loop! > > > > > > David > > > > I removed the second "while" statement and fixed the arguments to > > copy_to_iter - other than that, Al's function works. > > The extra while is easy to write and can be difficult to spot. > I've found them looking as the object code before now! That extra while comes from editing cut'n'pasted piece of source while writing a reply. Hint: original had been a do-while. > Oh - the error return for copy_to_iter() is wrong. > It should (probably) return 'total' if it is nonzero. copy_to_iter() call there has an obvious problem (arguments in the wrong order), but return value is handled correctly. It does not do a blind return -EFAULT. RTFS... _______________________________________________ Linux-nvdimm mailing list -- linux-nvdimm@lists.01.org To unsubscribe send an email to linux-nvdimm-leave@lists.01.org