Blame SOURCES/numactl-2.0.9-mpol-bind-preferred.patch

02ddd2
Date: Tue, 15 Jul 2014 13:53:14 -0400
02ddd2
From: Bill Gray <bgray@redhat.com>
02ddd2
To: linux-numa@vger.kernel.org
02ddd2
Cc: Cliff Wickman <cpw@sgi.com>
02ddd2
Subject: [PATCH] Fix numactl --show preferred node for case MPOL_BIND
02ddd2
02ddd2
This patch is mostly to fix an issue in "numactl --show" which did not 
02ddd2
print the correct preferred node:
02ddd2
02ddd2
# for i in 0 1 2 3 4 5 6 7 ; do numactl -N$i -m$i numactl -s; done | 
02ddd2
grep preferred
02ddd2
preferred node: 4
02ddd2
preferred node: 4
02ddd2
preferred node: 4
02ddd2
preferred node: 4
02ddd2
preferred node: 4
02ddd2
preferred node: 4
02ddd2
preferred node: 4
02ddd2
preferred node: 4
02ddd2
02ddd2
# for i in 0 1 2 3 4 5 6 7 ; do ./numactl -N$i -m$i ./numactl -s; done | 
02ddd2
grep preferred
02ddd2
preferred node: 0
02ddd2
preferred node: 1
02ddd2
preferred node: 2
02ddd2
preferred node: 3
02ddd2
preferred node: 4
02ddd2
preferred node: 5
02ddd2
preferred node: 6
02ddd2
preferred node: 7
02ddd2
02ddd2
Patch Changes:
02ddd2
- eliminated bitops.[cho]
02ddd2
- eliminated redundant printcpumask() (which duplicated printmask())
02ddd2
- added find_first() to util.[ch]
02ddd2
- fixed some compiler warnings
02ddd2
02ddd2
These files can be deleted:
02ddd2
- Only in numactl-2.0.9-orig/: bitops.c
02ddd2
- Only in numactl-2.0.9-orig/: bitops.h
02ddd2
- Only in numactl-2.0.9-orig/: numastat
02ddd2
- Only in numactl-2.0.9-orig/test: move_pages
02ddd2
02ddd2
diffstats:
02ddd2
  Makefile        |   12 ++++++------
02ddd2
  bitops.c        |   13 -------------
02ddd2
  bitops.h        |   13 -------------
02ddd2
  migspeed.c      |    4 +---
02ddd2
  numactl.c       |    5 ++---
02ddd2
  numaint.h       |    2 +-
02ddd2
  test/move_pages |binary
02ddd2
 Makefile       |   12 ++++++------
02ddd2
 bitops.c       |   13 -------------
02ddd2
 bitops.h       |   13 -------------
02ddd2
 migspeed.c     |    4 +---
02ddd2
 numactl.c      |    5 ++---
02ddd2
 numaint.h      |    2 +-
02ddd2
 test/nodemap.c |    1 -
02ddd2
 test/tbitmap.c |   10 +++++++++-
02ddd2
 util.c         |   14 +++++---------
02ddd2
 util.h         |    2 +-
02ddd2
 10 files changed, 25 insertions(+), 51 deletions(-)
02ddd2
02ddd2
Signed-off-by: Bill Gray <bgray@redhat.com>
02ddd2
02ddd2
Index: numactl-dev/bitops.c
02ddd2
===================================================================
02ddd2
--- numactl-dev.orig/bitops.c
02ddd2
+++ /dev/null
02ddd2
@@ -1,13 +0,0 @@
02ddd2
-#include "bitops.h"
02ddd2
-
02ddd2
-/* extremly dumb */
02ddd2
-int find_first_bit(void *m, int max)
02ddd2
-{
02ddd2
-	unsigned long *mask = m;
02ddd2
-	int i;
02ddd2
-	for (i = 0; i < max; i++) {
02ddd2
-		if (test_bit(i, mask))
02ddd2
-			break;			
02ddd2
-	}
02ddd2
-	return i;
02ddd2
-}
02ddd2
Index: numactl-dev/bitops.h
02ddd2
===================================================================
02ddd2
--- numactl-dev.orig/bitops.h
02ddd2
+++ /dev/null
02ddd2
@@ -1,13 +0,0 @@
02ddd2
-#ifndef BITOPS_H
02ddd2
-#define BITOPS_H 1
02ddd2
-
02ddd2
-#define BITS_PER_LONG (sizeof(unsigned long) * 8)
02ddd2
-#define BYTES_PER_LONG (sizeof(long))
02ddd2
-
02ddd2
-#define test_bit(i,p)  ((p)[(i) / BITS_PER_LONG] &   (1UL << ((i)%BITS_PER_LONG)))
02ddd2
-#define set_bit(i,p)   ((p)[(i) / BITS_PER_LONG] |=  (1UL << ((i)%BITS_PER_LONG)))
02ddd2
-#define clear_bit(i,p) ((p)[(i) / BITS_PER_LONG] &= ~(1UL << ((i)%BITS_PER_LONG)))
02ddd2
-
02ddd2
-extern int find_first_bit(void *mask, int max);
02ddd2
-
02ddd2
-#endif
02ddd2
Index: numactl-dev/Makefile
02ddd2
===================================================================
02ddd2
--- numactl-dev.orig/Makefile
02ddd2
+++ numactl-dev/Makefile
02ddd2
@@ -23,7 +23,7 @@ ifeq ($(THREAD_SUPPORT),yes)
02ddd2
 endif
02ddd2
 
02ddd2
 CLEANFILES := numactl.o libnuma.o numactl numademo numademo.o distance.o \
02ddd2
-	      memhog libnuma.so libnuma.so.1 numamon numamon.o syscall.o bitops.o \
02ddd2
+	      memhog libnuma.so libnuma.so.1 numamon numamon.o syscall.o \
02ddd2
 	      memhog.o util.o stream_main.o stream_lib.o shm.o stream clearcache.o \
02ddd2
 	      test/pagesize test/tshared test/mynode.o test/tshared.o mt.o empty.o empty.c \
02ddd2
 	      test/mynode test/ftok test/prefered test/randmap \
02ddd2
@@ -32,8 +32,8 @@ CLEANFILES := numactl.o libnuma.o numact
02ddd2
 	      test/mbind_mig_pages test/migrate_pages \
02ddd2
 	      migratepages migspeed migspeed.o libnuma.a \
02ddd2
 	      test/move_pages test/realloc_test sysfs.o affinity.o \
02ddd2
-	      test/node-parse rtnetlink.o test/A numastat
02ddd2
-SOURCES := bitops.c libnuma.c distance.c memhog.c numactl.c numademo.c \
02ddd2
+	      test/node-parse rtnetlink.o test/A numastat numastat.o
02ddd2
+SOURCES := libnuma.c distance.c memhog.c numactl.c numademo.c \
02ddd2
 	numamon.c shm.c stream_lib.c stream_main.c syscall.c util.c mt.c \
02ddd2
 	clearcache.c test/*.c affinity.c sysfs.c rtnetlink.c numastat.c
02ddd2
 
02ddd2
@@ -51,11 +51,11 @@ all: numactl migratepages migspeed libnu
02ddd2
      test/mbind_mig_pages test/migrate_pages test/realloc_test libnuma.a \
02ddd2
      test/node-parse numastat
02ddd2
 
02ddd2
-numactl: numactl.o util.o shm.o bitops.o libnuma.so
02ddd2
+numactl: numactl.o util.o shm.o libnuma.so
02ddd2
 
02ddd2
 numastat: CFLAGS += -std=gnu99
02ddd2
 
02ddd2
-migratepages: migratepages.c util.o bitops.o libnuma.so
02ddd2
+migratepages: migratepages.c util.o libnuma.so
02ddd2
 
02ddd2
 migspeed: LDLIBS += -lrt
02ddd2
 migspeed: migspeed.o util.o libnuma.so
02ddd2
@@ -129,7 +129,7 @@ test/nodemap: test/nodemap.c libnuma.so
02ddd2
 
02ddd2
 test/distance: test/distance.c libnuma.so
02ddd2
 
02ddd2
-test/tbitmap: test/tbitmap.c libnuma.so
02ddd2
+test/tbitmap: test/tbitmap.c libnuma.so util.o
02ddd2
 
02ddd2
 test/move_pages: test/move_pages.c libnuma.so
02ddd2
 
02ddd2
Index: numactl-dev/migspeed.c
02ddd2
===================================================================
02ddd2
--- numactl-dev.orig/migspeed.c
02ddd2
+++ numactl-dev/migspeed.c
02ddd2
@@ -65,7 +65,6 @@ int main(int argc, char *argv[])
02ddd2
 {
02ddd2
 	char *p;
02ddd2
 	int option;
02ddd2
-	int error = 0;
02ddd2
 	struct timespec result;
02ddd2
 	unsigned long bytes;
02ddd2
 	double duration, mbytes;
02ddd2
@@ -82,8 +81,7 @@ int main(int argc, char *argv[])
02ddd2
 	switch (option) {
02ddd2
 	case 'h' :
02ddd2
 	case '?' :
02ddd2
-		error = 1;
02ddd2
-		break;
02ddd2
+		usage();
02ddd2
 	case 'v' :
02ddd2
 		verbose++;
02ddd2
 		break;
02ddd2
Index: numactl-dev/numactl.c
02ddd2
===================================================================
02ddd2
--- numactl-dev.orig/numactl.c
02ddd2
+++ numactl-dev/numactl.c
02ddd2
@@ -119,7 +119,7 @@ void show_physcpubind(void)
02ddd2
 			}
02ddd2
 			err("sched_get_affinity");
02ddd2
 		}
02ddd2
-		printcpumask("physcpubind", cpubuf);
02ddd2
+		printmask("physcpubind", cpubuf);
02ddd2
 		break;
02ddd2
 	}
02ddd2
 }
02ddd2
@@ -130,7 +130,6 @@ void show(void)
02ddd2
 	struct bitmask *membind, *interleave, *cpubind;
02ddd2
 	unsigned long cur;
02ddd2
 	int policy;
02ddd2
-	int numa_num_nodes = numa_num_possible_nodes();
02ddd2
 	
02ddd2
 	if (numa_available() < 0) {
02ddd2
 		show_physcpubind();
02ddd2
@@ -166,7 +165,7 @@ void show(void)
02ddd2
 		printf("%ld (interleave next)\n",cur);
02ddd2
 		break;
02ddd2
 	case MPOL_BIND:
02ddd2
-		printf("%d\n", find_first_bit(&membind, numa_num_nodes));
02ddd2
+		printf("%d\n", find_first(membind));
02ddd2
 		break;
02ddd2
 	}
02ddd2
 	if (policy == MPOL_INTERLEAVE) {
02ddd2
Index: numactl-dev/numaint.h
02ddd2
===================================================================
02ddd2
--- numactl-dev.orig/numaint.h
02ddd2
+++ numactl-dev/numaint.h
02ddd2
@@ -1,5 +1,4 @@
02ddd2
 /* Internal interfaces of libnuma */
02ddd2
-#include "bitops.h"
02ddd2
 
02ddd2
 extern int numa_sched_setaffinity_v1(pid_t pid, unsigned len, const unsigned long *mask);
02ddd2
 extern int numa_sched_getaffinity_v1(pid_t pid, unsigned len, const unsigned long *mask);
02ddd2
@@ -12,6 +11,7 @@ extern int numa_sched_getaffinity_v2_int
02ddd2
 
02ddd2
 #define SHM_HUGETLB     04000   /* segment will use huge TLB pages */
02ddd2
 
02ddd2
+#define BITS_PER_LONG (sizeof(unsigned long) * 8)
02ddd2
 #define CPU_BYTES(x) (round_up(x, BITS_PER_LONG)/8)
02ddd2
 #define CPU_LONGS(x) (CPU_BYTES(x) / sizeof(long))
02ddd2
 
02ddd2
Index: numactl-dev/test/nodemap.c
02ddd2
===================================================================
02ddd2
--- numactl-dev.orig/test/nodemap.c
02ddd2
+++ numactl-dev/test/nodemap.c
02ddd2
@@ -1,5 +1,4 @@
02ddd2
 #include "numa.h"
02ddd2
-#include "bitops.h"
02ddd2
 #include <stdio.h>
02ddd2
 #include <stdlib.h>
02ddd2
 
02ddd2
Index: numactl-dev/test/tbitmap.c
02ddd2
===================================================================
02ddd2
--- numactl-dev.orig/test/tbitmap.c
02ddd2
+++ numactl-dev/test/tbitmap.c
02ddd2
@@ -7,6 +7,13 @@
02ddd2
 #include <stdlib.h>
02ddd2
 #include <ctype.h>
02ddd2
 #include "numa.h"
02ddd2
+#include "util.h"
02ddd2
+
02ddd2
+/* For util.c. Fixme. */
02ddd2
+void usage(void)
02ddd2
+{
02ddd2
+	exit(1);
02ddd2
+}
02ddd2
 
02ddd2
 #define ALIGN(x,a) (((x)+(a)-1)&~((a)-1))
02ddd2
 
02ddd2
@@ -81,11 +88,12 @@ int main(void)
02ddd2
 		numa_bitmask_clearall(mask);
02ddd2
 		numa_bitmask_clearall(mask2);
02ddd2
 		numa_bitmask_setbit(mask, i);
02ddd2
+		assert(find_first(mask) == i);
02ddd2
 		bitmap_scnprintf(buf, sizeof(buf), mask);
02ddd2
 		strcat(buf,"\n");
02ddd2
 		if (numa_parse_bitmap(buf, mask2) < 0)
02ddd2
 			assert(0);
02ddd2
-		if (memcmp(mask, mask2, sizeof(mask))) { 
02ddd2
+		if (memcmp(mask->maskp, mask2->maskp, numa_bitmask_nbytes(mask))) {
02ddd2
 			bitmap_scnprintf(buf, sizeof(buf), mask2);
02ddd2
 			printf("mask2 differs: %s\n", buf);
02ddd2
 			assert(0);
02ddd2
Index: numactl-dev/util.c
02ddd2
===================================================================
02ddd2
--- numactl-dev.orig/util.c
02ddd2
+++ numactl-dev/util.c
02ddd2
@@ -16,7 +16,6 @@
02ddd2
 #include "numa.h"
02ddd2
 #include "numaif.h"
02ddd2
 #include "util.h"
02ddd2
-#include "bitops.h"
02ddd2
 #include <stdio.h>
02ddd2
 #include <string.h>
02ddd2
 #include <stdlib.h>
02ddd2
@@ -28,23 +27,20 @@
02ddd2
 void printmask(char *name, struct bitmask *mask)
02ddd2
 {
02ddd2
 	int i;
02ddd2
-
02ddd2
 	printf("%s: ", name);
02ddd2
-	for (i = 0; i <= mask->size; i++)
02ddd2
+	for (i = 0; i < mask->size; i++)
02ddd2
 		if (numa_bitmask_isbitset(mask, i))
02ddd2
 			printf("%d ", i);
02ddd2
 	putchar('\n');
02ddd2
 }
02ddd2
 
02ddd2
-void printcpumask(char *name, struct bitmask *mask)
02ddd2
+int find_first(struct bitmask *mask)
02ddd2
 {
02ddd2
 	int i;
02ddd2
-	printf("%s: ", name);
02ddd2
-	for (i = 0; i < mask->size; i++) {
02ddd2
+	for (i = 0; i < mask->size; i++)
02ddd2
 		if (numa_bitmask_isbitset(mask, i))
02ddd2
-			printf("%d ", i);
02ddd2
-	}
02ddd2
-	putchar('\n');
02ddd2
+			return i;
02ddd2
+	return -1;
02ddd2
 }
02ddd2
 
02ddd2
 void complain(char *fmt, ...)
02ddd2
Index: numactl-dev/util.h
02ddd2
===================================================================
02ddd2
--- numactl-dev.orig/util.h
02ddd2
+++ numactl-dev/util.h
02ddd2
@@ -1,5 +1,5 @@
02ddd2
 extern void printmask(char *name, struct bitmask *mask);
02ddd2
-extern void printcpumask(char *name, struct bitmask *mask);
02ddd2
+extern int find_first(struct bitmask *mask);
02ddd2
 extern struct bitmask *nodemask(char *s);
02ddd2
 extern struct bitmask *cpumask(char *s, int *ncpus);
02ddd2
 extern int read_sysctl(char *name);