2079c3
From c465ca7ca41aa03e755ed71fa0281c620b0d8dc0 Mon Sep 17 00:00:00 2001
2079c3
From: Harish <harish@linux.vnet.ibm.com>
2079c3
Date: Thu, 21 Jun 2018 17:22:36 +0530
2079c3
Subject: [PATCH 3/7] Fix: distance test to include all existing nodes
2079c3
2079c3
The previous implementation did not consider memory-less nodes as
2079c3
numa_num_configured_nodes() returns only nodes with memory and
2079c3
numa_node_size() check is unnecessary for distance check. Hence
2079c3
removed the check for memory.
2079c3
2079c3
Signed-off-by: Harish <harish@linux.vnet.ibm.com>
2079c3
Signed-off-by: Pingfan Liu <piliu@redhat.com>
2079c3
---
2079c3
 test/distance.c | 11 +++++------
2079c3
 1 file changed, 5 insertions(+), 6 deletions(-)
2079c3
2079c3
diff --git a/test/distance.c b/test/distance.c
2079c3
index fca109f..3471db6 100644
2079c3
--- a/test/distance.c
2079c3
+++ b/test/distance.c
2079c3
@@ -5,21 +5,20 @@
2079c3
 
2079c3
 int main(void)
2079c3
 {
2079c3
-	int numnodes, maxnode, a, b, got_nodes = 0;
2079c3
+	int maxnode, a, b, got_nodes = 0;
2079c3
 	int *node_to_use;
2079c3
-	long size, free_node_sizes;
2079c3
 	if (numa_available() < 0) {
2079c3
 		printf("no numa support in kernel\n");
2079c3
 		exit(1);
2079c3
 	}
2079c3
-	numnodes = numa_num_configured_nodes();
2079c3
 	maxnode = numa_max_node();
2079c3
-	node_to_use = (int *)malloc(numnodes * sizeof(int));
2079c3
+	node_to_use = (int *)malloc(maxnode * sizeof(int));
2079c3
 	for (a = 0; a <= maxnode; a++) {
2079c3
-		size = numa_node_size(a, &free_node_sizes);
2079c3
-		if(size != -1)
2079c3
+		if (numa_bitmask_isbitset(numa_nodes_ptr, a)){
2079c3
 			node_to_use[got_nodes++] = a;
2079c3
+		}
2079c3
 	}
2079c3
+
2079c3
 	for (a = 0; a < got_nodes; a++){
2079c3
 		printf("%03d: ", node_to_use[a]);
2079c3
 		if (numa_distance(node_to_use[a], node_to_use[a]) != 10) {
2079c3
-- 
2079c3
2.7.4
2079c3