summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Morton <akpm@digeo.com>2002-10-31 20:02:31 -0800
committerLinus Torvalds <torvalds@home.transmeta.com>2002-10-31 20:02:31 -0800
commit7c265fe6370fc05acb39ee919bdfacd42f96c7fb (patch)
treea305e6913d6a68a9cc228ba20f9d4c77d33dec76
parent6e8b708eb14ca90a08bf679ff4503ce3ec8effc1 (diff)
[PATCH] create node_online_map
From Matthew Dobson. Create and use node_online_map. This patch creates a node_online_map, much like cpu_online_map. It also creates the standard helper functions, ie: node_online(), num_online_nodes(), node_set_online(), node_set_offline(). This is used by driverFS topology to keep track of which Nodes are in the system and online.
-rw-r--r--arch/i386/kernel/numaq.c1
-rw-r--r--arch/i386/mach-generic/topology.c4
-rw-r--r--include/linux/mmzone.h23
-rw-r--r--mm/page_alloc.c1
4 files changed, 26 insertions, 3 deletions
diff --git a/arch/i386/kernel/numaq.c b/arch/i386/kernel/numaq.c
index 07cf91d92dd9..d5d0968e9d55 100644
--- a/arch/i386/kernel/numaq.c
+++ b/arch/i386/kernel/numaq.c
@@ -52,6 +52,7 @@ static void __init smp_dump_qct(void)
numnodes = 0;
for(node = 0; node < MAX_NUMNODES; node++) {
if(scd->quads_present31_0 & (1 << node)) {
+ node_set_online(node);
numnodes++;
eq = &scd->eq[node];
/* Convert to pages */
diff --git a/arch/i386/mach-generic/topology.c b/arch/i386/mach-generic/topology.c
index a066cc7f4877..a89d8762687d 100644
--- a/arch/i386/mach-generic/topology.c
+++ b/arch/i386/mach-generic/topology.c
@@ -38,13 +38,11 @@ struct i386_cpu cpu_devices[NR_CPUS];
struct i386_node node_devices[MAX_NUMNODES];
struct i386_memblk memblk_devices[MAX_NR_MEMBLKS];
-extern int numnodes;
-
static int __init topology_init(void)
{
int i;
- for (i = 0; i < numnodes; i++)
+ for (i = 0; i < num_online_nodes(); i++)
arch_register_node(i);
for (i = 0; i < NR_CPUS; i++)
if (cpu_possible(i)) arch_register_cpu(i);
diff --git a/include/linux/mmzone.h b/include/linux/mmzone.h
index be4f03235e3d..3e004bc2ff63 100644
--- a/include/linux/mmzone.h
+++ b/include/linux/mmzone.h
@@ -280,10 +280,25 @@ extern struct pglist_data contig_page_data;
#endif /* !CONFIG_DISCONTIGMEM */
+extern DECLARE_BITMAP(node_online_map, MAX_NUMNODES);
extern DECLARE_BITMAP(memblk_online_map, MAX_NR_MEMBLKS);
#if defined(CONFIG_DISCONTIGMEM) || defined(CONFIG_NUMA)
+#define node_online(node) test_bit(node, node_online_map)
+#define node_set_online(node) set_bit(node, node_online_map)
+#define node_set_offline(node) clear_bit(node, node_online_map)
+static inline unsigned int num_online_nodes(void)
+{
+ int i, num = 0;
+
+ for(i = 0; i < MAX_NUMNODES; i++){
+ if (node_online(i))
+ num++;
+ }
+ return num;
+}
+
#define memblk_online(memblk) test_bit(memblk, memblk_online_map)
#define memblk_set_online(memblk) set_bit(memblk, memblk_online_map)
#define memblk_set_offline(memblk) clear_bit(memblk, memblk_online_map)
@@ -300,6 +315,14 @@ static inline unsigned int num_online_memblks(void)
#else /* !CONFIG_DISCONTIGMEM && !CONFIG_NUMA */
+#define node_online(node) \
+ ({ BUG_ON((node) != 0); test_bit(node, node_online_map); })
+#define node_set_online(node) \
+ ({ BUG_ON((node) != 0); set_bit(node, node_online_map); })
+#define node_set_offline(node) \
+ ({ BUG_ON((node) != 0); clear_bit(node, node_online_map); })
+#define num_online_nodes() 1
+
#define memblk_online(memblk) \
({ BUG_ON((memblk) != 0); test_bit(memblk, memblk_online_map); })
#define memblk_set_online(memblk) \
diff --git a/mm/page_alloc.c b/mm/page_alloc.c
index 54ddc18b1e81..10b1ad95a8ae 100644
--- a/mm/page_alloc.c
+++ b/mm/page_alloc.c
@@ -31,6 +31,7 @@
#include <asm/topology.h>
+DECLARE_BITMAP(node_online_map, MAX_NUMNODES);
DECLARE_BITMAP(memblk_online_map, MAX_NR_MEMBLKS);
struct pglist_data *pgdat_list;
unsigned long totalram_pages;