diff options
author | Christoph Hellwig <hch@lst.de> | 2022-09-15 10:41:56 +0100 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2022-09-20 08:24:38 -0600 |
commit | 176042404ee6a96ba7e9054e1bda6220360a26ad (patch) | |
tree | 26cda2b524748ba30e1d7604bb8d14bd21ba16c8 /include/linux/pagemap.h | |
parent | e88480871b8d5a6bd14be2817063363202d282b9 (diff) | |
download | lwn-176042404ee6a96ba7e9054e1bda6220360a26ad.tar.gz lwn-176042404ee6a96ba7e9054e1bda6220360a26ad.zip |
mm: add PSI accounting around ->read_folio and ->readahead calls
PSI tries to account for the cost of bringing back in pages discarded by
the MM LRU management. Currently the prime place for that is hooked into
the bio submission path, which is a rather bad place:
- it does not actually account I/O for non-block file systems, of which
we have many
- it adds overhead and a layering violation to the block layer
Add the accounting into the two places in the core MM code that read
pages into an address space by calling into ->read_folio and ->readahead
so that the entire file system operations are covered, to broaden
the coverage and allow removing the accounting in the block layer going
forward.
As psi_memstall_enter can deal with nested calls this will not lead to
double accounting even while the bio annotations are still present.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Acked-by: Johannes Weiner <hannes@cmpxchg.org>
Link: https://lore.kernel.org/r/20220915094200.139713-2-hch@lst.de
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'include/linux/pagemap.h')
-rw-r--r-- | include/linux/pagemap.h | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/include/linux/pagemap.h b/include/linux/pagemap.h index 0178b2040ea3..201dc7281640 100644 --- a/include/linux/pagemap.h +++ b/include/linux/pagemap.h @@ -1173,6 +1173,8 @@ struct readahead_control { pgoff_t _index; unsigned int _nr_pages; unsigned int _batch_count; + bool _workingset; + unsigned long _pflags; }; #define DEFINE_READAHEAD(ractl, f, r, m, i) \ |