[PATCH v5 34/39] mm: Add DEFINE_READAHEAD

From: Matthew Wilcox
Date: Thu May 28 2020 - 22:59:20 EST


From: "Matthew Wilcox (Oracle)" <willy@xxxxxxxxxxxxx>

Allow for a more concise definition of a struct readahead_control.

Signed-off-by: Matthew Wilcox (Oracle) <willy@xxxxxxxxxxxxx>
---
include/linux/pagemap.h | 7 +++++++
mm/readahead.c | 6 +-----
2 files changed, 8 insertions(+), 5 deletions(-)

diff --git a/include/linux/pagemap.h b/include/linux/pagemap.h
index 0b4a4b62b585..84ba69477e3b 100644
--- a/include/linux/pagemap.h
+++ b/include/linux/pagemap.h
@@ -719,6 +719,13 @@ struct readahead_control {
unsigned int _batch_count;
};

+#define DEFINE_READAHEAD(rac, f, m, i) \
+ struct readahead_control rac = { \
+ .file = f, \
+ .mapping = m, \
+ ._index = i, \
+ }
+
/**
* readahead_page - Get the next page to read.
* @rac: The current readahead request.
diff --git a/mm/readahead.c b/mm/readahead.c
index 3c9a8dd7c56c..2126a2754e22 100644
--- a/mm/readahead.c
+++ b/mm/readahead.c
@@ -179,11 +179,7 @@ void page_cache_readahead_unbounded(struct address_space *mapping,
{
LIST_HEAD(page_pool);
gfp_t gfp_mask = readahead_gfp_mask(mapping);
- struct readahead_control rac = {
- .mapping = mapping,
- .file = file,
- ._index = index,
- };
+ DEFINE_READAHEAD(rac, file, mapping, index);
unsigned long i;

/*
--
2.26.2