Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp1372172pxk; Fri, 4 Sep 2020 07:51:38 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzz0KRyz+BZiOT2JDsOVzLjwiLzAzSYDSpXb/T9+aRzZteBVADqPRjGs+G6DXAGcOtSi4ST X-Received: by 2002:a17:906:6010:: with SMTP id o16mr7495487ejj.320.1599231098394; Fri, 04 Sep 2020 07:51:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1599231098; cv=none; d=google.com; s=arc-20160816; b=wtZQDHCOP17fDLvWUgI+VoZIfF4uz1pn6fdDiON5K+G+N32hTwk5/ZwM4q9RdK8KYy AV4VxAhC9j5/mSYhhaIZN3lrjo3ke2quzWEy27rRdN0KFrYncQc6v0c/DlHBHoAUvLVR OJq5zV5pXnn1EmVlhYqfRtXMm40o7/5uO0I8au8vGPXZAhqTZjsLMrzX9bCFUT/rSttM h25YGqJ87lASmXsAzt+zkyy9KTgS3NpBXj07Xiwnt4F0WuRxUJFvcf6Jlzp8F3c/hV66 GrSTd+n6f5dG85buEmfUGur3kxRzA/dRmVMKtVVD+RzOZngwCmPRlacg2J61ZOREYRJ0 kc/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=knHcGvrKe47dDgMpklf6EaakjMbICjDQ8kPM7SJOe0g=; b=QrBTTLlQmh8UydZvFO62s6d6xYwohDGXkdRINydsfNip5bCD6cosNxg8BLQBjnodRe TWeUDjS7vk6YjGq6MYzC8owL7NlSG7FI8QMEQ0UgS8yAfRTbujXhhqJyiMi/3SpaAvCW ftQP1rZqwBuqM7OtL9aQnwHhcJxkHz3SULkymIt/RMhTfc0sF0acgGROhbBi7rsTeRgZ 9zoiqHD1SgIFRkuvt4NmXahgcbDcqvq6jRngEzsrEbwJKFZYfOwhEgRTn2yulzPrM3ny GmS5q95Hx1KdhBGEiQf5cnWrJWFHUthLK3lz9JrsuVIAlFsQ3EaP3TOI2Xua6Rjq930/ /YdQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=qFs5cdTi; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j19si683400ejx.272.2020.09.04.07.51.15; Fri, 04 Sep 2020 07:51:38 -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=@gmail.com header.s=20161025 header.b=qFs5cdTi; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730204AbgIDOuH (ORCPT + 99 others); Fri, 4 Sep 2020 10:50:07 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35104 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729942AbgIDOuF (ORCPT ); Fri, 4 Sep 2020 10:50:05 -0400 Received: from mail-ej1-x642.google.com (mail-ej1-x642.google.com [IPv6:2a00:1450:4864:20::642]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 94AF6C061244 for ; Fri, 4 Sep 2020 07:50:04 -0700 (PDT) Received: by mail-ej1-x642.google.com with SMTP id e23so9002461eja.3 for ; Fri, 04 Sep 2020 07:50:04 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=knHcGvrKe47dDgMpklf6EaakjMbICjDQ8kPM7SJOe0g=; b=qFs5cdTin+4XJ14I4314k+lczV2OimLtbY/+jRukUPSyAUxnaIgf3jAMinYQIAPTdc fbW2UfhTnzV3WbKFk++GolYrJIYMt0Zo239oodSDZUE3UbttkPV3lhyX4s9eqQl89CXL yjIt4EJV3QiTBRDE0KyX4NqhwbWFyPaoISFsVSS1o7o3cuw6Jvcqy9uG+tLOTmctJxJv GcBL0y3oFdOtGvt5XVrSRxReSqRptxFI2NipW1G/KlmHn7TlT2hH1adwGUpGtGS4etw6 d+J8zBCamQJhcekfXzbw0mccYToTZeuR/Z9unLyhPd68JHDUs0ihp1wr8P/uLhXRSzoF FVRg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=knHcGvrKe47dDgMpklf6EaakjMbICjDQ8kPM7SJOe0g=; b=de4D6aMozR26SGIibPqtFUzxvBLH2cffTbQloTLtHIHP8j5QOwbZoJGzWBODW839aX AT+7N+NO8/vAmGNChopVpvxnfu3L1BTn9Wo/bldax+OH2FBT2j+NTtaiG7Lsn/W0ubE/ ANGoKGvkhgXzc2oa/IzV1WqFw+sTceWLP3kNcFmqeepUSkd/NGzQBGNCcafXkDDJed2E sfxxzdma1YcbEV6MCLdSiyKdAVqB/0z5Di0GC838c7emyUzInfekxnDCutvLGnvHZ/q8 /TiI0jDdaoagg22HdI5yZtXFCRMUb9eiFP0lXZtkLXdnVifR4lsANjgsFf82j0MMwNrR MoIA== X-Gm-Message-State: AOAM532xviLQvZbs8A03Gv5oQlnFsuLNWIHtNqKDHgP+oo0xg5IwNIXW ux/2hUrQX+Tcd2pyFPekVZo= X-Received: by 2002:a17:906:1909:: with SMTP id a9mr7562396eje.127.1599231003271; Fri, 04 Sep 2020 07:50:03 -0700 (PDT) Received: from localhost.localdomain ([2a01:598:b907:ef64:1d41:83f0:a723:a7e3]) by smtp.gmail.com with ESMTPSA id v17sm6281327eju.22.2020.09.04.07.50.01 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 04 Sep 2020 07:50:02 -0700 (PDT) From: Bean Huo To: akpm@linux-foundation.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org Cc: beanhuo@micron.com Subject: [PATCH RFC] mm: Let readahead submit larger batches of pages in case of ra->ra_pages == 0 Date: Fri, 4 Sep 2020 16:48:07 +0200 Message-Id: <20200904144807.31810-1-huobean@gmail.com> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Bean Huo Current generic_file_buffered_read() will break up the larger batches of pages and read data in single page length in case of ra->ra_pages == 0. This patch is to allow it to pass the batches of pages down to the device if the supported maximum IO size >= the requested size. Signed-off-by: Bean Huo --- mm/filemap.c | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/mm/filemap.c b/mm/filemap.c index 1aaea26556cc..0deec1897817 100644 --- a/mm/filemap.c +++ b/mm/filemap.c @@ -2062,6 +2062,7 @@ ssize_t generic_file_buffered_read(struct kiocb *iocb, struct file *filp = iocb->ki_filp; struct address_space *mapping = filp->f_mapping; struct inode *inode = mapping->host; + struct backing_dev_info *bdi = inode_to_bdi(mapping->host); struct file_ra_state *ra = &filp->f_ra; loff_t *ppos = &iocb->ki_pos; pgoff_t index; @@ -2098,9 +2099,14 @@ ssize_t generic_file_buffered_read(struct kiocb *iocb, if (!page) { if (iocb->ki_flags & IOCB_NOIO) goto would_block; - page_cache_sync_readahead(mapping, - ra, filp, - index, last_index - index); + + if (!ra->ra_pages && bdi->io_pages >= last_index - index) + __do_page_cache_readahead(mapping, filp, index, + last_index - index, 0); + else + page_cache_sync_readahead(mapping, ra, filp, + index, + last_index - index); page = find_get_page(mapping, index); if (unlikely(page == NULL)) goto no_cached_page; -- 2.17.1