diff options
author | Alex Chiang <achiang@hp.com> | 2009-12-14 20:59:05 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-12-15 11:53:17 -0500 |
commit | dee5d0d518defd0337a41f1a504428c9acc87be5 (patch) | |
tree | deb540b5ccc58f0e83114509e17dacb281fc12e5 | |
parent | d99be1a8ecf377c2c9b3372d36411ad6547bbd4c (diff) |
mm: add numa node symlink for memory section in sysfs
Commit c04fc586c (mm: show node to memory section relationship with
symlinks in sysfs) created symlinks from nodes to memory sections, e.g.
/sys/devices/system/node/node1/memory135 -> ../../memory/memory135
If you're examining the memory section though and are wondering what node
it might belong to, you can find it by grovelling around in sysfs, but
it's a little cumbersome.
Add a reverse symlink for each memory section that points back to the
node to which it belongs.
Signed-off-by: Alex Chiang <achiang@hp.com>
Cc: Gary Hade <garyhade@us.ibm.com>
Cc: Badari Pulavarty <pbadari@us.ibm.com>
Cc: Ingo Molnar <mingo@elte.hu>
Acked-by: David Rientjes <rientjes@google.com>
Cc: Greg KH <greg@kroah.com>
Cc: Randy Dunlap <randy.dunlap@oracle.com>
Cc: David Rientjes <rientjes@google.com>
Cc: KOSAKI Motohiro <kosaki.motohiro@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-memory | 14 | ||||
-rw-r--r-- | Documentation/memory-hotplug.txt | 11 | ||||
-rw-r--r-- | drivers/base/node.c | 11 |
3 files changed, 30 insertions, 6 deletions
diff --git a/Documentation/ABI/testing/sysfs-devices-memory b/Documentation/ABI/testing/sysfs-devices-memory index 9fe91c02ee40..bf1627b02a03 100644 --- a/Documentation/ABI/testing/sysfs-devices-memory +++ b/Documentation/ABI/testing/sysfs-devices-memory | |||
@@ -60,6 +60,19 @@ Description: | |||
60 | Users: hotplug memory remove tools | 60 | Users: hotplug memory remove tools |
61 | https://w3.opensource.ibm.com/projects/powerpc-utils/ | 61 | https://w3.opensource.ibm.com/projects/powerpc-utils/ |
62 | 62 | ||
63 | |||
64 | What: /sys/devices/system/memoryX/nodeY | ||
65 | Date: October 2009 | ||
66 | Contact: Linux Memory Management list <linux-mm@kvack.org> | ||
67 | Description: | ||
68 | When CONFIG_NUMA is enabled, a symbolic link that | ||
69 | points to the corresponding NUMA node directory. | ||
70 | |||
71 | For example, the following symbolic link is created for | ||
72 | memory section 9 on node0: | ||
73 | /sys/devices/system/memory/memory9/node0 -> ../../node/node0 | ||
74 | |||
75 | |||
63 | What: /sys/devices/system/node/nodeX/memoryY | 76 | What: /sys/devices/system/node/nodeX/memoryY |
64 | Date: September 2008 | 77 | Date: September 2008 |
65 | Contact: Gary Hade <garyhade@us.ibm.com> | 78 | Contact: Gary Hade <garyhade@us.ibm.com> |
@@ -70,4 +83,3 @@ Description: | |||
70 | memory section directory. For example, the following symbolic | 83 | memory section directory. For example, the following symbolic |
71 | link is created for memory section 9 on node0. | 84 | link is created for memory section 9 on node0. |
72 | /sys/devices/system/node/node0/memory9 -> ../../memory/memory9 | 85 | /sys/devices/system/node/node0/memory9 -> ../../memory/memory9 |
73 | |||
diff --git a/Documentation/memory-hotplug.txt b/Documentation/memory-hotplug.txt index bbc8a6a36921..57e7e9cc1870 100644 --- a/Documentation/memory-hotplug.txt +++ b/Documentation/memory-hotplug.txt | |||
@@ -160,12 +160,15 @@ Under each section, you can see 4 files. | |||
160 | NOTE: | 160 | NOTE: |
161 | These directories/files appear after physical memory hotplug phase. | 161 | These directories/files appear after physical memory hotplug phase. |
162 | 162 | ||
163 | If CONFIG_NUMA is enabled the | 163 | If CONFIG_NUMA is enabled the memoryXXX/ directories can also be accessed |
164 | /sys/devices/system/memory/memoryXXX memory section | 164 | via symbolic links located in the /sys/devices/system/node/node* directories. |
165 | directories can also be accessed via symbolic links located in | 165 | |
166 | the /sys/devices/system/node/node* directories. For example: | 166 | For example: |
167 | /sys/devices/system/node/node0/memory9 -> ../../memory/memory9 | 167 | /sys/devices/system/node/node0/memory9 -> ../../memory/memory9 |
168 | 168 | ||
169 | A backlink will also be created: | ||
170 | /sys/devices/system/memory/memory9/node0 -> ../../node/node0 | ||
171 | |||
169 | -------------------------------- | 172 | -------------------------------- |
170 | 4. Physical memory hot-add phase | 173 | 4. Physical memory hot-add phase |
171 | -------------------------------- | 174 | -------------------------------- |
diff --git a/drivers/base/node.c b/drivers/base/node.c index 54e5d8eaf70e..44eed11bbdf3 100644 --- a/drivers/base/node.c +++ b/drivers/base/node.c | |||
@@ -312,6 +312,7 @@ static int get_nid_for_pfn(unsigned long pfn) | |||
312 | /* register memory section under specified node if it spans that node */ | 312 | /* register memory section under specified node if it spans that node */ |
313 | int register_mem_sect_under_node(struct memory_block *mem_blk, int nid) | 313 | int register_mem_sect_under_node(struct memory_block *mem_blk, int nid) |
314 | { | 314 | { |
315 | int ret; | ||
315 | unsigned long pfn, sect_start_pfn, sect_end_pfn; | 316 | unsigned long pfn, sect_start_pfn, sect_end_pfn; |
316 | 317 | ||
317 | if (!mem_blk) | 318 | if (!mem_blk) |
@@ -328,9 +329,15 @@ int register_mem_sect_under_node(struct memory_block *mem_blk, int nid) | |||
328 | continue; | 329 | continue; |
329 | if (page_nid != nid) | 330 | if (page_nid != nid) |
330 | continue; | 331 | continue; |
331 | return sysfs_create_link_nowarn(&node_devices[nid].sysdev.kobj, | 332 | ret = sysfs_create_link_nowarn(&node_devices[nid].sysdev.kobj, |
332 | &mem_blk->sysdev.kobj, | 333 | &mem_blk->sysdev.kobj, |
333 | kobject_name(&mem_blk->sysdev.kobj)); | 334 | kobject_name(&mem_blk->sysdev.kobj)); |
335 | if (ret) | ||
336 | return ret; | ||
337 | |||
338 | return sysfs_create_link_nowarn(&mem_blk->sysdev.kobj, | ||
339 | &node_devices[nid].sysdev.kobj, | ||
340 | kobject_name(&node_devices[nid].sysdev.kobj)); | ||
334 | } | 341 | } |
335 | /* mem section does not span the specified node */ | 342 | /* mem section does not span the specified node */ |
336 | return 0; | 343 | return 0; |
@@ -359,6 +366,8 @@ int unregister_mem_sect_under_nodes(struct memory_block *mem_blk) | |||
359 | continue; | 366 | continue; |
360 | sysfs_remove_link(&node_devices[nid].sysdev.kobj, | 367 | sysfs_remove_link(&node_devices[nid].sysdev.kobj, |
361 | kobject_name(&mem_blk->sysdev.kobj)); | 368 | kobject_name(&mem_blk->sysdev.kobj)); |
369 | sysfs_remove_link(&mem_blk->sysdev.kobj, | ||
370 | kobject_name(&node_devices[nid].sysdev.kobj)); | ||
362 | } | 371 | } |
363 | return 0; | 372 | return 0; |
364 | } | 373 | } |