提交 7964c06d 编写于 作者: J Jason Liu 提交者: Linus Torvalds

mm: compaction: fix echo 1 > compact_memory return error issue

when run the folloing command under shell, it will return error

  sh/$ echo 1 > /proc/sys/vm/compact_memory
  sh/$ sh: write error: Bad address

After strace, I found the following log:

  ...
  write(1, "1\n", 2)               = 3
  write(1, "", 4294967295)         = -1 EFAULT (Bad address)
  write(2, "echo: write error: Bad address\n", 31echo: write error: Bad address
  ) = 31

This tells system return 3(COMPACT_COMPLETE) after write data to
compact_memory.

The fix is to make the system just return 0 instead 3(COMPACT_COMPLETE)
from sysctl_compaction_handler after compaction_nodes finished.
Signed-off-by: NJason Liu <r64343@freescale.com>
Suggested-by: NDavid Rientjes <rientjes@google.com>
Acked-by: NMel Gorman <mgorman@suse.de>
Cc: Rik van Riel <riel@redhat.com>
Cc: Minchan Kim <minchan@kernel.org>
Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Acked-by: NDavid Rientjes <rientjes@google.com>
Cc: <stable@vger.kernel.org>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 c0232ae8
...@@ -1210,7 +1210,7 @@ static int compact_node(int nid) ...@@ -1210,7 +1210,7 @@ static int compact_node(int nid)
} }
/* Compact all nodes in the system */ /* Compact all nodes in the system */
static int compact_nodes(void) static void compact_nodes(void)
{ {
int nid; int nid;
...@@ -1219,8 +1219,6 @@ static int compact_nodes(void) ...@@ -1219,8 +1219,6 @@ static int compact_nodes(void)
for_each_online_node(nid) for_each_online_node(nid)
compact_node(nid); compact_node(nid);
return COMPACT_COMPLETE;
} }
/* The written value is actually unused, all memory is compacted */ /* The written value is actually unused, all memory is compacted */
...@@ -1231,7 +1229,7 @@ int sysctl_compaction_handler(struct ctl_table *table, int write, ...@@ -1231,7 +1229,7 @@ int sysctl_compaction_handler(struct ctl_table *table, int write,
void __user *buffer, size_t *length, loff_t *ppos) void __user *buffer, size_t *length, loff_t *ppos)
{ {
if (write) if (write)
return compact_nodes(); compact_nodes();
return 0; return 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册