Received: by 2002:a05:6a10:c604:0:0:0:0 with SMTP id y4csp884527pxt; Fri, 6 Aug 2021 16:57:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxnwp57eo5a5c9A3KN78pIcqHna4wwHXxgh28qAElF7lUbJfHLk73sd4uIL6+w9JVUM8dfn X-Received: by 2002:a92:d3c7:: with SMTP id c7mr79343ilh.59.1628294240757; Fri, 06 Aug 2021 16:57:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628294240; cv=none; d=google.com; s=arc-20160816; b=rynj9MhMvfEXHLuYFp0B8eIJkr2nqvR4DhnDz6NMiGdEH6CN6jeQ/6V3amU3d88wD0 5eqVwFhwKkYY8XuGsoFNyBaXRs4tWJ4kocR5E7v5F+b4PZ19eBVez+i6FP5lkNyhLsms 1B+jynreM5CfLVGhGHjfJdUD6xL03a2H5F8rISsHc2xM47Qha9BToZEEXgfWOt9z51Hw bvyZMnHMPTr3F8iDDY06AUUVqITMVR7j40Z4C+NbUMjbtPQcqQ4uXhMlXn1Phpdue7W5 HYi3piIU4CEeNeUsoKVjeHD5Penz51Vp4efQrBRAj6dqrZydmYa/lRW3Bg4zsjQOtA61 L0+w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=oVXTKnqxAtSSQ4IhMfAUss53lifoLdXxsRc2hm5fWQk=; b=1In7hXy/xkS7RxLcejig2mix0ENJPbD3WdovJAsWfw8NLRfPTXKhQXZHg1G54mkOHn gc9kpW/tkehjVQh1ScSo/ejASvoYa7SigtewEhYM/OucKqWqovA+4OMnDq18P0cc5jBi +IXTctGV87XJmvry4vvP/kV8yYRYtjEczef6J4ePbHAnIIs1Q6LtP7215zNKdQEDgdRp chTcaHhnSFAA9X9hjLCHvX4wL9Rwj4vT6NvIPv63P7U1QSwVaUNlKVA/IUstkaSCMoZ7 Kf32g2Af65AKyvaLf6Ka/wz9wjg7Xji9k5EipwcTZgVZMptU1kuizmjjTqhvRuhdV5Za iPdw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel-dk.20150623.gappssmtp.com header.s=20150623 header.b=CKiEOTFM; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r3si10550580jan.7.2021.08.06.16.57.09; Fri, 06 Aug 2021 16:57:20 -0700 (PDT) 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=@kernel-dk.20150623.gappssmtp.com header.s=20150623 header.b=CKiEOTFM; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240960AbhHFRSt (ORCPT + 99 others); Fri, 6 Aug 2021 13:18:49 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40566 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229480AbhHFRSt (ORCPT ); Fri, 6 Aug 2021 13:18:49 -0400 Received: from mail-pj1-x1030.google.com (mail-pj1-x1030.google.com [IPv6:2607:f8b0:4864:20::1030]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 88086C0613CF for ; Fri, 6 Aug 2021 10:18:32 -0700 (PDT) Received: by mail-pj1-x1030.google.com with SMTP id nh14so17676299pjb.2 for ; Fri, 06 Aug 2021 10:18:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=kernel-dk.20150623.gappssmtp.com; s=20150623; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=oVXTKnqxAtSSQ4IhMfAUss53lifoLdXxsRc2hm5fWQk=; b=CKiEOTFMQ/3Qhx3l95vADApRAr8YPPIFXI/RiO+DD/FyUWwQfMxAnGTngzfs52GjZ6 5r1dJW2Us6NBnCA83uqa155Jw5+amCYHYpJ9G8Bdo02LqmseJ57BuKTPTmMsTyE5VfVq eHzdXhw1BtFQx7jHy9kLKOYgkuP0ssSOLDQUmqL9ucWxONXNM0uJAESLQpurrF9X7MXz WVKRPTXdI1l8vWAkjFzwjtJpG9rxxPgFt0Zv9AGQlExsDrXCyb39QJBrM7savbMvHNQY 2k64LWPeFgCpd/KyNaDMU2bB6Mt0hHJADcNttsxIp9A4GrK7Otefc/RYyRdAY+sZu29e MTtg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=oVXTKnqxAtSSQ4IhMfAUss53lifoLdXxsRc2hm5fWQk=; b=kAjX6qmK3p8LVviI62QRyuDH5tLCfUSZAKsYZLRXNPoforP/J15ReRPsRqMVTEmNNs sqBIJkdKTfASABabgmx3WPg8FJLhDUhCOZxJRsyIx3yHMUBE1sPywCjkrAzf7P2S/qed /pP81PsF0lz7C1bsoYValGLpg7O9leY2Y2YRQcYdJdH/P9MJ+PYZwLf0+ism1+xj4V7S hzVQ9RvSnN+XnkjBvH94lM/EzUkXH509XYyKtp08GEJI2w4aqM75+F3Swphmo0GiBb4k zV0SzddH+4efFo14jlYWP1W6p8grTK8lKLTRChBpoytoPt0MmusVUryeIRSr3cTMKYKh x3dQ== X-Gm-Message-State: AOAM5338zNaAhbj3akFKc+nGpgd4AV9CKsOgYLA+gka4nC0gkavAxXCg VgpIb7bq9tD8YOKtXgXPtWpKARFS6X1dtiKT X-Received: by 2002:a17:90a:5889:: with SMTP id j9mr21720768pji.117.1628270311027; Fri, 06 Aug 2021 10:18:31 -0700 (PDT) Received: from [192.168.1.116] ([198.8.77.61]) by smtp.gmail.com with ESMTPSA id c24sm13239677pgj.11.2021.08.06.10.18.29 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 06 Aug 2021 10:18:30 -0700 (PDT) Subject: Re: [RFC] mm: optimise generic_file_read_iter To: Al Viro , Pavel Begunkov Cc: Andrew Morton , linux-mm@kvack.org, linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org References: <07bd408d6cad95166b776911823b40044160b434.1628248975.git.asml.silence@gmail.com> From: Jens Axboe Message-ID: Date: Fri, 6 Aug 2021 11:18:28 -0600 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 8/6/21 7:48 AM, Al Viro wrote: > On Fri, Aug 06, 2021 at 12:42:43PM +0100, Pavel Begunkov wrote: >> Unless direct I/O path of generic_file_read_iter() ended up with an >> error or a short read, it doesn't use inode. So, load inode and size >> later, only when they're needed. This cuts two memory reads and also >> imrpoves code generation, e.g. loads from stack. > > ... and the same question here. > >> NOTE: as a side effect, it reads inode->i_size after ->direct_IO(), and >> I'm not sure whether that's valid, so would be great to get feedback >> from someone who knows better. > > Ought to be safe, I think, but again, how much effect have you observed > from the patch? Ran a quick test here, doing polled IO (~3.3M IOPS) and we reduce the overhead of generic_file_read_iter() from 1.5% of the runtime to 1.2%. Noticeable. Will improve once we stop digging into the inode on the io_uring side. Anyway, just one data point, perhaps Pavel has some too. -- Jens Axboe