linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
* [Patch v2] mm/migrate.c: also overwrite error when it is bigger than zero
@ 2020-01-19  6:57 Wei Yang
  2020-01-21  1:53 ` Wei Yang
  2020-01-24  7:21 ` Michal Hocko
  0 siblings, 2 replies; 12+ messages in thread
From: Wei Yang @ 2020-01-19  6:57 UTC (permalink / raw)
  To: akpm, yang.shi, jhubbard, vbabka, cl; +Cc: linux-mm, linux-kernel, Wei Yang

If we get here after successfully adding page to list, err would be
1 to indicate the page is queued in the list.

Current code has two problems:

  * on success, 0 is not returned
  * on error, if add_page_for_migratioin() return 1, and the following err1
    from do_move_pages_to_node() is set, the err1 is not returned since err
    is 1

And these behaviors break the user interface.

Fixes: e0153fc2c760 ("mm: move_pages: return valid node id in status if the
page is already on the target node").
Signed-off-by: Wei Yang <richardw.yang@linux.intel.com>

---
v2:
  * put more words to explain the error case
---
 mm/migrate.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/mm/migrate.c b/mm/migrate.c
index 86873b6f38a7..430fdccc733e 100644
--- a/mm/migrate.c
+++ b/mm/migrate.c
@@ -1676,7 +1676,7 @@ static int do_pages_move(struct mm_struct *mm, nodemask_t task_nodes,
 	err1 = do_move_pages_to_node(mm, &pagelist, current_node);
 	if (!err1)
 		err1 = store_status(status, start, current_node, i - start);
-	if (!err)
+	if (err >= 0)
 		err = err1;
 out:
 	return err;
-- 
2.17.1



^ permalink raw reply related	[flat|nested] 12+ messages in thread

end of thread, other threads:[~2020-01-24 15:31 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2020-01-19  6:57 [Patch v2] mm/migrate.c: also overwrite error when it is bigger than zero Wei Yang
2020-01-21  1:53 ` Wei Yang
2020-01-21  2:34   ` Wei Yang
2020-01-21 19:33     ` John Hubbard
2020-01-22  0:42       ` Wei Yang
2020-01-22  1:29         ` John Hubbard
2020-01-21 19:30   ` Yang Shi
2020-01-22  0:41     ` Wei Yang
2020-01-24  7:21 ` Michal Hocko
2020-01-24 14:15   ` Wei Yang
2020-01-24 14:46     ` Michal Hocko
2020-01-24 15:28       ` Wei Yang

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).