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=-3.8 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS 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 B63B5C43469 for ; Mon, 21 Sep 2020 16:28:06 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 7F9AB2396D for ; Mon, 21 Sep 2020 16:28:06 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728265AbgIUQ2F (ORCPT ); Mon, 21 Sep 2020 12:28:05 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59906 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727323AbgIUQ2F (ORCPT ); Mon, 21 Sep 2020 12:28:05 -0400 Received: from ZenIV.linux.org.uk (zeniv.linux.org.uk [IPv6:2002:c35c:fd02::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BAC5CC061755; Mon, 21 Sep 2020 09:28:04 -0700 (PDT) Received: from viro by ZenIV.linux.org.uk with local (Exim 4.92.3 #3 (Red Hat Linux)) id 1kKOfR-003EDr-FT; Mon, 21 Sep 2020 16:27:53 +0000 Date: Mon, 21 Sep 2020 17:27:53 +0100 From: Al Viro To: David Laight Cc: Christoph Hellwig , Andrew Morton , Jens Axboe , Arnd Bergmann , David Howells , "linux-arm-kernel@lists.infradead.org" , "linux-kernel@vger.kernel.org" , "linux-mips@vger.kernel.org" , "linux-parisc@vger.kernel.org" , "linuxppc-dev@lists.ozlabs.org" , "linux-s390@vger.kernel.org" , "sparclinux@vger.kernel.org" , "linux-block@vger.kernel.org" , "linux-scsi@vger.kernel.org" , "linux-fsdevel@vger.kernel.org" , "linux-aio@kvack.org" , "io-uring@vger.kernel.org" , "linux-arch@vger.kernel.org" , "linux-mm@kvack.org" , "netdev@vger.kernel.org" , "keyrings@vger.kernel.org" , "linux-security-module@vger.kernel.org" Subject: Re: [PATCH 02/11] mm: call import_iovec() instead of rw_copy_check_uvector() in process_vm_rw() Message-ID: <20200921162753.GY3421308@ZenIV.linux.org.uk> References: <20200921143434.707844-1-hch@lst.de> <20200921143434.707844-3-hch@lst.de> <20200921150211.GS3421308@ZenIV.linux.org.uk> <20200921152937.GX3421308@ZenIV.linux.org.uk> <226e03bf941844eba4d64af31633c177@AcuMS.aculab.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <226e03bf941844eba4d64af31633c177@AcuMS.aculab.com> Sender: Al Viro Precedence: bulk List-ID: X-Mailing-List: linux-fsdevel@vger.kernel.org On Mon, Sep 21, 2020 at 03:44:00PM +0000, David Laight wrote: > From: Al Viro > > Sent: 21 September 2020 16:30 > > > > On Mon, Sep 21, 2020 at 03:21:35PM +0000, David Laight wrote: > > > > > You really don't want to be looping through the array twice. > > > > Profiles, please. > > I did some profiling of send() v sendmsg() much earlier in the year. > I can't remember the exact details but the extra cost of sendmsg() > is far more than you might expect. > (I was timing sending fully built IPv4 UDP packets using a raw socket.) > > About half the difference does away if you change the > copy_from_user() to __copy_from_user() when reading the struct msghdr > and iov[] from userspace (user copy hardening is expensive). Wha...? So the difference is within 4 times the overhead of the hardening checks done for one call of copy_from_user()? > The rest is just code path, my gut feeling is that a lot of that > is in import_iovec(). > > Remember semdmsg() is likely to be called with an iov count of 1. ... which makes that loop unlikely to be noticable in the entire mess, whether you pass it once or twice. IOW, unless you can show profiles where that loop is sufficiently hot or if you can show the timings change from splitting it in two, I'll remain very sceptical about that assertion.