2 * Copyright (c) 2012 The DragonFly Project. All rights reserved.
4 * This code is derived from software contributed to The DragonFly Project
5 * by Matthew Dillon <dillon@backplane.com> and Thomas Nikolajsen
6 * <thomas.nikolajsen@mail.dk>
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in
16 * the documentation and/or other materials provided with the
18 * 3. Neither the name of The DragonFly Project nor the names of its
19 * contributors may be used to endorse or promote products derived
20 * from this software without specific, prior written permission.
22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
25 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
26 * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
27 * INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING,
28 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
30 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
31 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
32 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
36 #include <sys/types.h>
37 #include <sys/usched.h>
38 #include <sys/cpumask.h>
44 static void usage(void);
49 main(int ac
, char **av
)
55 char *sched_cpustr
= NULL
;
59 pid_t pid
= getpid(); /* See usched_set(2) - BUGS */
61 CPUMASK_ASSZERO(cpumask
);
63 while ((ch
= getopt(ac
, av
, "d")) != -1) {
80 sched_cpustr
= strdup(av
[0]);
81 sched
= strsep(&sched_cpustr
, ":");
82 if (strcmp(sched
, "default") == 0)
84 "Ignoring scheduler == \"default\": "
86 cpustr
= strsep(&sched_cpustr
, "");
87 if (strlen(sched
) == 0 && cpustr
== NULL
) {
93 * XXX needs expanded support for > 64 cpus
102 if (baseid
>= CPU_SETSIZE
) {
103 fprintf(stderr
, "cpumask too large\n");
106 v
= (uint64_t)strtoull(ptr
, &ptr
, 0);
107 for (cpuid
= 0; cpuid
< (int)sizeof(v
) * 8; ++cpuid
) {
108 if (v
& (1LU << cpuid
))
109 CPUMASK_ORBIT(cpumask
, baseid
+ cpuid
);
114 fprintf(stderr
, "cpumask format error\n");
118 baseid
+= (int)sizeof(v
) * 8;
122 if (strlen(sched
) != 0) {
125 "DEBUG: USCHED_SET_SCHEDULER: scheduler: %s\n",
128 res
= usched_set(pid
, USCHED_SET_SCHEDULER
,
129 sched
, strlen(sched
));
132 "usched_set(%d, USCHED_SET_SCHEDULER, "
134 pid
, sched
, (int)strlen(sched
));
139 if (CPUMASK_TESTNZERO(cpumask
)) {
140 for (cpuid
= 0; cpuid
< CPU_SETSIZE
; ++cpuid
) {
141 if (CPUMASK_TESTBIT(cpumask
, cpuid
))
145 fprintf(stderr
, "DEBUG: USCHED_SET_CPU: cpuid: %d\n",
148 res
= usched_set(pid
, USCHED_SET_CPU
, &cpuid
, sizeof(int));
150 asprintf(&p
, "usched_set(%d, USCHED_SET_CPU, &%d, %d)",
151 pid
, cpuid
, (int)sizeof(int));
155 CPUMASK_NANDBIT(cpumask
, cpuid
);
156 while (CPUMASK_TESTNZERO(cpumask
)) {
158 if (CPUMASK_TESTBIT(cpumask
, cpuid
) == 0)
160 CPUMASK_NANDBIT(cpumask
, cpuid
);
163 "DEBUG: USCHED_ADD_CPU: cpuid: %d\n",
166 res
= usched_set(pid
, USCHED_ADD_CPU
,
167 &cpuid
, sizeof(int));
170 "usched_set(%d, USCHED_ADD_CPU, "
172 pid
, cpuid
, (int)sizeof(int));
178 execvp(av
[1], av
+ 1);
187 "usage: usched [-d] {scheduler[:cpumask] | :cpumask} "
188 "program [argument ...]\n");
190 "cpumask format: val[,val[,val[,val]]] in 64-bit chunks, "
191 "lsb chunk first\n");