Neil Horman 9d951c
diff -up numactl-1.0.2/numactl.c.orig numactl-1.0.2/numactl.c
Neil Horman 9d951c
--- numactl-1.0.2/numactl.c.orig	2007-09-21 06:23:51.000000000 -0400
Neil Horman 9d951c
+++ numactl-1.0.2/numactl.c	2008-04-25 09:10:05.000000000 -0400
Neil Horman 9d951c
@@ -355,14 +355,14 @@ int main(int ac, char **av)
Neil Horman 9d951c
 			break;
Neil Horman 9d951c
 		case 'C': /* --physcpubind */
Neil Horman 9d951c
 		{
Neil Horman 9d951c
-			int ncpus;
Neil Horman 9d951c
+			int bufsz;
Neil Horman 9d951c
 			unsigned long *cpubuf;
Neil Horman 9d951c
 			dontshm("-C/--physcpubind");
Neil Horman 9d951c
-			cpubuf = cpumask(optarg, &ncpus);
Neil Horman 9d951c
+			cpubuf = cpumask(optarg, &bufsz);
Neil Horman 9d951c
 			errno = 0;
Neil Horman 9d951c
 			check_cpubind(do_shm);
Neil Horman 9d951c
 			did_cpubind = 1;
Neil Horman 9d951c
-			numa_sched_setaffinity(0, CPU_BYTES(ncpus), cpubuf);
Neil Horman 9d951c
+			numa_sched_setaffinity(0, bufsz, cpubuf);
Neil Horman 9d951c
 			checkerror("sched_setaffinity");
Neil Horman 9d951c
 			free(cpubuf);
Neil Horman 9d951c
 			break;
Neil Horman 9d951c
diff -up numactl-1.0.2/util.h.orig numactl-1.0.2/util.h
Neil Horman 9d951c
--- numactl-1.0.2/util.h.orig	2007-08-16 10:36:23.000000000 -0400
Neil Horman 9d951c
+++ numactl-1.0.2/util.h	2008-04-25 09:10:05.000000000 -0400
Neil Horman 9d951c
@@ -1,7 +1,7 @@
Neil Horman 9d951c
 extern void printmask(char *name, nodemask_t *mask);
Neil Horman 9d951c
 extern void printcpumask(char *name, unsigned long *mask, int len);
Neil Horman 9d951c
 extern nodemask_t nodemask(char *s);
Neil Horman 9d951c
-extern unsigned long *cpumask(char *s, int *ncpus);
Neil Horman 9d951c
+extern unsigned long *cpumask(char *s, int *bufsz);
Neil Horman 9d951c
 extern int read_sysctl(char *name);
Neil Horman 9d951c
 extern void complain(char *fmt, ...);
Neil Horman 9d951c
 extern void nerror(char *fmt, ...);
Neil Horman 9d951c
diff -up numactl-1.0.2/util.c.orig numactl-1.0.2/util.c
Neil Horman 9d951c
--- numactl-1.0.2/util.c.orig	2007-08-16 10:36:23.000000000 -0400
Neil Horman 9d951c
+++ numactl-1.0.2/util.c	2008-04-25 09:10:45.000000000 -0400
Neil Horman 9d951c
@@ -52,7 +52,7 @@ void printmask(char *name, nodemask_t *m
Neil Horman 9d951c
 int numcpus; 
Neil Horman 9d951c
 
Neil Horman 9d951c
 /* caller must free buffer */
Neil Horman 9d951c
-unsigned long *cpumask(char *s, int *ncpus) 
Neil Horman 9d951c
+unsigned long *cpumask(char *s, int *bufsz) 
Neil Horman 9d951c
 {
Neil Horman 9d951c
 	int invert = 0;
Neil Horman 9d951c
 	char *end; 
Neil Horman 9d951c
@@ -92,7 +92,7 @@ unsigned long *cpumask(char *s, int *ncp
Neil Horman 9d951c
 			unsigned long arg2 = strtoul(++s, &end2, 0); 
Neil Horman 9d951c
 			if (end2 == s)
Neil Horman 9d951c
 				complain("missing cpu argument %s\n", s);
Neil Horman 9d951c
-			if (arg > numcpus)
Neil Horman 9d951c
+			if (arg >= numcpus)
Neil Horman 9d951c
 				complain("cpu argument %d out of range\n", arg);
Neil Horman 9d951c
 			while (++arg <= arg2)
Neil Horman 9d951c
 				set_bit(arg, cpubuf);
Neil Horman 9d951c
@@ -110,7 +110,7 @@ unsigned long *cpumask(char *s, int *ncp
Neil Horman 9d951c
 				set_bit(i, cpubuf);
Neil Horman 9d951c
 		}
Neil Horman 9d951c
 	} 
Neil Horman 9d951c
-	*ncpus = cpubufsize;
Neil Horman 9d951c
+	*bufsz = cpubufsize;
Neil Horman 9d951c
 	return cpubuf;	
Neil Horman 9d951c
 }
Neil Horman 9d951c