diff options
author | Mel Gorman <mel@csn.ul.ie> | 2010-05-24 17:32:29 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2010-05-25 11:06:59 -0400 |
commit | ed4a6d7f0676db50b5023cc01f6cda82a2f2a307 (patch) | |
tree | 6496343ba964e105cf30f8703714471f22edc806 | |
parent | 76ab0f530e4a01d4dc20cdc1d5e87753c579dc18 (diff) |
mm: compaction: add /sys trigger for per-node memory compaction
Add a per-node sysfs file called compact. When the file is written to,
each zone in that node is compacted. The intention that this would be
used by something like a job scheduler in a batch system before a job
starts so that the job can allocate the maximum number of hugepages
without significant start-up cost.
Signed-off-by: Mel Gorman <mel@csn.ul.ie>
Acked-by: Rik van Riel <riel@redhat.com>
Reviewed-by: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com>
Reviewed-by: Christoph Lameter <cl@linux-foundation.org>
Reviewed-by: Minchan Kim <minchan.kim@gmail.com>
Reviewed-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | Documentation/ABI/testing/sysfs-devices-node | 7 | ||||
-rw-r--r-- | drivers/base/node.c | 3 | ||||
-rw-r--r-- | include/linux/compaction.h | 16 | ||||
-rw-r--r-- | mm/compaction.c | 23 |
4 files changed, 49 insertions, 0 deletions
diff --git a/Documentation/ABI/testing/sysfs-devices-node b/Documentation/ABI/testing/sysfs-devices-node new file mode 100644 index 00000000000..453a210c3ce --- /dev/null +++ b/Documentation/ABI/testing/sysfs-devices-node | |||
@@ -0,0 +1,7 @@ | |||
1 | What: /sys/devices/system/node/nodeX/compact | ||
2 | Date: February 2010 | ||
3 | Contact: Mel Gorman <mel@csn.ul.ie> | ||
4 | Description: | ||
5 | When this file is written to, all memory within that node | ||
6 | will be compacted. When it completes, memory will be freed | ||
7 | into blocks which have as many contiguous pages as possible | ||
diff --git a/drivers/base/node.c b/drivers/base/node.c index 057979a19ee..2bdd8a94ec9 100644 --- a/drivers/base/node.c +++ b/drivers/base/node.c | |||
@@ -9,6 +9,7 @@ | |||
9 | #include <linux/memory.h> | 9 | #include <linux/memory.h> |
10 | #include <linux/node.h> | 10 | #include <linux/node.h> |
11 | #include <linux/hugetlb.h> | 11 | #include <linux/hugetlb.h> |
12 | #include <linux/compaction.h> | ||
12 | #include <linux/cpumask.h> | 13 | #include <linux/cpumask.h> |
13 | #include <linux/topology.h> | 14 | #include <linux/topology.h> |
14 | #include <linux/nodemask.h> | 15 | #include <linux/nodemask.h> |
@@ -246,6 +247,8 @@ int register_node(struct node *node, int num, struct node *parent) | |||
246 | scan_unevictable_register_node(node); | 247 | scan_unevictable_register_node(node); |
247 | 248 | ||
248 | hugetlb_register_node(node); | 249 | hugetlb_register_node(node); |
250 | |||
251 | compaction_register_node(node); | ||
249 | } | 252 | } |
250 | return error; | 253 | return error; |
251 | } | 254 | } |
diff --git a/include/linux/compaction.h b/include/linux/compaction.h index 572388880ba..ba98cfe0ae1 100644 --- a/include/linux/compaction.h +++ b/include/linux/compaction.h | |||
@@ -12,4 +12,20 @@ extern int sysctl_compaction_handler(struct ctl_table *table, int write, | |||
12 | void __user *buffer, size_t *length, loff_t *ppos); | 12 | void __user *buffer, size_t *length, loff_t *ppos); |
13 | #endif /* CONFIG_COMPACTION */ | 13 | #endif /* CONFIG_COMPACTION */ |
14 | 14 | ||
15 | #if defined(CONFIG_COMPACTION) && defined(CONFIG_SYSFS) && defined(CONFIG_NUMA) | ||
16 | extern int compaction_register_node(struct node *node); | ||
17 | extern void compaction_unregister_node(struct node *node); | ||
18 | |||
19 | #else | ||
20 | |||
21 | static inline int compaction_register_node(struct node *node) | ||
22 | { | ||
23 | return 0; | ||
24 | } | ||
25 | |||
26 | static inline void compaction_unregister_node(struct node *node) | ||
27 | { | ||
28 | } | ||
29 | #endif /* CONFIG_COMPACTION && CONFIG_SYSFS && CONFIG_NUMA */ | ||
30 | |||
15 | #endif /* _LINUX_COMPACTION_H */ | 31 | #endif /* _LINUX_COMPACTION_H */ |
diff --git a/mm/compaction.c b/mm/compaction.c index 77854fbc0f5..f61f77983ff 100644 --- a/mm/compaction.c +++ b/mm/compaction.c | |||
@@ -13,6 +13,7 @@ | |||
13 | #include <linux/mm_inline.h> | 13 | #include <linux/mm_inline.h> |
14 | #include <linux/backing-dev.h> | 14 | #include <linux/backing-dev.h> |
15 | #include <linux/sysctl.h> | 15 | #include <linux/sysctl.h> |
16 | #include <linux/sysfs.h> | ||
16 | #include "internal.h" | 17 | #include "internal.h" |
17 | 18 | ||
18 | /* | 19 | /* |
@@ -453,3 +454,25 @@ int sysctl_compaction_handler(struct ctl_table *table, int write, | |||
453 | 454 | ||
454 | return 0; | 455 | return 0; |
455 | } | 456 | } |
457 | |||
458 | #if defined(CONFIG_SYSFS) && defined(CONFIG_NUMA) | ||
459 | ssize_t sysfs_compact_node(struct sys_device *dev, | ||
460 | struct sysdev_attribute *attr, | ||
461 | const char *buf, size_t count) | ||
462 | { | ||
463 | compact_node(dev->id); | ||
464 | |||
465 | return count; | ||
466 | } | ||
467 | static SYSDEV_ATTR(compact, S_IWUSR, NULL, sysfs_compact_node); | ||
468 | |||
469 | int compaction_register_node(struct node *node) | ||
470 | { | ||
471 | return sysdev_create_file(&node->sysdev, &attr_compact); | ||
472 | } | ||
473 | |||
474 | void compaction_unregister_node(struct node *node) | ||
475 | { | ||
476 | return sysdev_remove_file(&node->sysdev, &attr_compact); | ||
477 | } | ||
478 | #endif /* CONFIG_SYSFS && CONFIG_NUMA */ | ||