Patch "NFS: Fix /proc/PID/io read_bytes for buffered reads" has been added to the 6.2-stable tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



This is a note to let you know that I've just added the patch titled

    NFS: Fix /proc/PID/io read_bytes for buffered reads

to the 6.2-stable tree which can be found at:
    http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary

The filename of the patch is:
     nfs-fix-proc-pid-io-read_bytes-for-buffered-reads.patch
and it can be found in the queue-6.2 subdirectory.

If you, or anyone else, feels it should not be added to the stable tree,
please let <stable@xxxxxxxxxxxxxxx> know about it.



commit e511bb74ded04ed236026152f81a4c277bb096dd
Author: Dave Wysochanski <dwysocha@xxxxxxxxxx>
Date:   Thu Mar 9 13:58:52 2023 -0500

    NFS: Fix /proc/PID/io read_bytes for buffered reads
    
    [ Upstream commit 9c88ea00fef03031ce6554531e89be82f6a42835 ]
    
    Prior to commit 8786fde8421c ("Convert NFS from readpages to
    readahead"), nfs_readpages() used the old mm interface read_cache_pages()
    which called task_io_account_read() for each NFS page read.  After
    this commit, nfs_readpages() is converted to nfs_readahead(), which
    now uses the new mm interface readahead_page().  The new interface
    requires callers to call task_io_account_read() themselves.
    In addition, to nfs_readahead() task_io_account_read() should also
    be called from nfs_read_folio().
    
    Fixes: 8786fde8421c ("Convert NFS from readpages to readahead")
    Link: https://lore.kernel.org/linux-nfs/CAPt2mGNEYUk5u8V4abe=5MM5msZqmvzCVrtCP4Qw1n=gCHCnww@xxxxxxxxxxxxxx/
    Signed-off-by: Dave Wysochanski <dwysocha@xxxxxxxxxx>
    Signed-off-by: Anna Schumaker <Anna.Schumaker@xxxxxxxxxx>
    Signed-off-by: Sasha Levin <sashal@xxxxxxxxxx>

diff --git a/fs/nfs/read.c b/fs/nfs/read.c
index 8ae2c8d1219d8..cd970ce62786b 100644
--- a/fs/nfs/read.c
+++ b/fs/nfs/read.c
@@ -15,6 +15,7 @@
 #include <linux/stat.h>
 #include <linux/mm.h>
 #include <linux/slab.h>
+#include <linux/task_io_accounting_ops.h>
 #include <linux/pagemap.h>
 #include <linux/sunrpc/clnt.h>
 #include <linux/nfs_fs.h>
@@ -338,6 +339,7 @@ int nfs_read_folio(struct file *file, struct folio *folio)
 
 	trace_nfs_aop_readpage(inode, page);
 	nfs_inc_stats(inode, NFSIOS_VFSREADPAGE);
+	task_io_account_read(folio_size(folio));
 
 	/*
 	 * Try to flush any pending writes to the file..
@@ -400,6 +402,7 @@ void nfs_readahead(struct readahead_control *ractl)
 
 	trace_nfs_aop_readahead(inode, readahead_pos(ractl), nr_pages);
 	nfs_inc_stats(inode, NFSIOS_VFSREADPAGES);
+	task_io_account_read(readahead_length(ractl));
 
 	ret = -ESTALE;
 	if (NFS_STALE(inode))



[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux