aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPovilas Kanapickas <povilas@radix.lt>2018-01-13 23:27:37 +0200
committerDenys Vlasenko <vda.linux@googlemail.com>2018-01-23 16:04:48 +0100
commit0f6e4350b3c36b3b4533d0ea910481e28d5f81ab (patch)
tree3394e56ccd93fbbe7bf9d5118f175b5a9234e50a
parent1616fb8aca23fd7ba6b379b0fb38d3327d1e31d1 (diff)
downloadbusybox-w32-0f6e4350b3c36b3b4533d0ea910481e28d5f81ab.tar.gz
busybox-w32-0f6e4350b3c36b3b4533d0ea910481e28d5f81ab.tar.bz2
busybox-w32-0f6e4350b3c36b3b4533d0ea910481e28d5f81ab.zip
chrt: add support for SCHED_IDLE
Signed-off-by: Povilas Kanapickas <povilas@radix.lt> Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r--util-linux/chrt.c21
1 files changed, 13 insertions, 8 deletions
diff --git a/util-linux/chrt.c b/util-linux/chrt.c
index e7abd4f5a..bbd6e2deb 100644
--- a/util-linux/chrt.c
+++ b/util-linux/chrt.c
@@ -17,7 +17,7 @@
17//kbuild:lib-$(CONFIG_CHRT) += chrt.o 17//kbuild:lib-$(CONFIG_CHRT) += chrt.o
18 18
19//usage:#define chrt_trivial_usage 19//usage:#define chrt_trivial_usage
20//usage: "[-prfomb] [PRIO] [PID | PROG ARGS]" 20//usage: "[-prfombi] [PRIO] [PID | PROG ARGS]"
21//usage:#define chrt_full_usage "\n\n" 21//usage:#define chrt_full_usage "\n\n"
22//usage: "Change scheduling priority and class for a process\n" 22//usage: "Change scheduling priority and class for a process\n"
23//usage: "\n -p Operate on PID" 23//usage: "\n -p Operate on PID"
@@ -25,6 +25,7 @@
25//usage: "\n -f Set SCHED_FIFO class" 25//usage: "\n -f Set SCHED_FIFO class"
26//usage: "\n -o Set SCHED_OTHER class" 26//usage: "\n -o Set SCHED_OTHER class"
27//usage: "\n -b Set SCHED_BATCH class" 27//usage: "\n -b Set SCHED_BATCH class"
28//usage: "\n -i Set SCHED_IDLE class"
28//usage: "\n -m Show min/max priorities" 29//usage: "\n -m Show min/max priorities"
29//usage: 30//usage:
30//usage:#define chrt_example_usage 31//usage:#define chrt_example_usage
@@ -42,12 +43,11 @@ static const struct {
42 {SCHED_OTHER, "SCHED_OTHER"}, 43 {SCHED_OTHER, "SCHED_OTHER"},
43 {SCHED_FIFO, "SCHED_FIFO"}, 44 {SCHED_FIFO, "SCHED_FIFO"},
44 {SCHED_RR, "SCHED_RR"}, 45 {SCHED_RR, "SCHED_RR"},
45 {SCHED_BATCH, "SCHED_BATCH"} 46 {SCHED_BATCH, "SCHED_BATCH"},
47 {0 /* unused */, ""},
48 {SCHED_IDLE, "SCHED_IDLE"}
46}; 49};
47 50
48//TODO: add
49// -i, SCHED_IDLE
50
51static void show_min_max(int pol) 51static void show_min_max(int pol)
52{ 52{
53 const char *fmt = "%s min/max priority\t: %u/%u\n"; 53 const char *fmt = "%s min/max priority\t: %u/%u\n";
@@ -66,6 +66,7 @@ static void show_min_max(int pol)
66#define OPT_f (1<<3) 66#define OPT_f (1<<3)
67#define OPT_o (1<<4) 67#define OPT_o (1<<4)
68#define OPT_b (1<<5) 68#define OPT_b (1<<5)
69#define OPT_i (1<<6)
69 70
70int chrt_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; 71int chrt_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
71int chrt_main(int argc UNUSED_PARAM, char **argv) 72int chrt_main(int argc UNUSED_PARAM, char **argv)
@@ -79,12 +80,13 @@ int chrt_main(int argc UNUSED_PARAM, char **argv)
79 int policy = SCHED_RR; 80 int policy = SCHED_RR;
80 81
81 /* only one policy accepted */ 82 /* only one policy accepted */
82 opt = getopt32(argv, "^+" "mprfob" "\0" "r--fob:f--rob:o--rfb:b--rfo"); 83 opt = getopt32(argv, "^+" "mprfobi" "\0" "r--fobi:f--robi:o--rfbi:b--rfoi:i--rfob");
83 if (opt & OPT_m) { /* print min/max and exit */ 84 if (opt & OPT_m) { /* print min/max and exit */
84 show_min_max(SCHED_FIFO); 85 show_min_max(SCHED_FIFO);
85 show_min_max(SCHED_RR); 86 show_min_max(SCHED_RR);
86 show_min_max(SCHED_OTHER); 87 show_min_max(SCHED_OTHER);
87 show_min_max(SCHED_BATCH); 88 show_min_max(SCHED_BATCH);
89 show_min_max(SCHED_IDLE);
88 fflush_stdout_and_exit(EXIT_SUCCESS); 90 fflush_stdout_and_exit(EXIT_SUCCESS);
89 } 91 }
90 if (opt & OPT_r) 92 if (opt & OPT_r)
@@ -95,6 +97,8 @@ int chrt_main(int argc UNUSED_PARAM, char **argv)
95 policy = SCHED_OTHER; 97 policy = SCHED_OTHER;
96 if (opt & OPT_b) 98 if (opt & OPT_b)
97 policy = SCHED_BATCH; 99 policy = SCHED_BATCH;
100 if (opt & OPT_i)
101 policy = SCHED_IDLE;
98 102
99 argv += optind; 103 argv += optind;
100 if (!argv[0]) 104 if (!argv[0])
@@ -138,11 +142,12 @@ int chrt_main(int argc UNUSED_PARAM, char **argv)
138 142
139 /* from the manpage of sched_getscheduler: 143 /* from the manpage of sched_getscheduler:
140 [...] sched_priority can have a value in the range 0 to 99. 144 [...] sched_priority can have a value in the range 0 to 99.
141 [...] SCHED_OTHER or SCHED_BATCH must be assigned static priority 0. 145 [...] SCHED_OTHER, SCHED_BATCH or SCHED_IDLE must be assigned static
146 priority 0.
142 [...] SCHED_FIFO or SCHED_RR can have static priority in 1..99 range. 147 [...] SCHED_FIFO or SCHED_RR can have static priority in 1..99 range.
143 */ 148 */
144 sp.sched_priority = xstrtou_range(priority, 0, 149 sp.sched_priority = xstrtou_range(priority, 0,
145 (policy != SCHED_OTHER && policy != SCHED_BATCH) ? 1 : 0, 99); 150 (policy != SCHED_OTHER && policy != SCHED_BATCH && policy != SCHED_IDLE) ? 1 : 0, 99);
146 151
147 if (sched_setscheduler(pid, policy, &sp) < 0) 152 if (sched_setscheduler(pid, policy, &sp) < 0)
148 bb_perror_msg_and_die("can't %cet pid %d's policy", 's', (int)pid); 153 bb_perror_msg_and_die("can't %cet pid %d's policy", 's', (int)pid);