summaryrefslogtreecommitdiffstats
path: root/mm/memory-failure.c
diff options
context:
space:
mode:
authorXianting Tian <tian.xianting@h3c.com>2020-10-14 01:54:42 +0200
committerLinus Torvalds <torvalds@linux-foundation.org>2020-10-14 03:38:32 +0200
commitc43bc03d0a872dcfcaaf1689c4f6140f9d3cb867 (patch)
treefa6677e16c4c40e2564e6db9945a6d99b12302fb /mm/memory-failure.c
parentmm/dmapool.c: replace hard coded function name with __func__ (diff)
downloadlinux-c43bc03d0a872dcfcaaf1689c4f6140f9d3cb867.tar.xz
linux-c43bc03d0a872dcfcaaf1689c4f6140f9d3cb867.zip
mm/memory-failure: do pgoff calculation before for_each_process()
There is no need to calculate pgoff in each loop of for_each_process(), so move it to the place before for_each_process(), which can save some CPU cycles. Signed-off-by: Xianting Tian <tian.xianting@h3c.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Acked-by: Naoya Horiguchi <naoya.horiguchi@nec.com> Link: http://lkml.kernel.org/r/20200818082647.34322-1-tian.xianting@h3c.com Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to '')
-rw-r--r--mm/memory-failure.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/mm/memory-failure.c b/mm/memory-failure.c
index a1e73943445e..24c28f80628d 100644
--- a/mm/memory-failure.c
+++ b/mm/memory-failure.c
@@ -484,11 +484,12 @@ static void collect_procs_file(struct page *page, struct list_head *to_kill,
struct vm_area_struct *vma;
struct task_struct *tsk;
struct address_space *mapping = page->mapping;
+ pgoff_t pgoff;
i_mmap_lock_read(mapping);
read_lock(&tasklist_lock);
+ pgoff = page_to_pgoff(page);
for_each_process(tsk) {
- pgoff_t pgoff = page_to_pgoff(page);
struct task_struct *t = task_early_kill(tsk, force_early);
if (!t)