[PATCH] Support for CFS SCHED_IDLE priority in chrt

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Please keep CC to linux-kernel or CC to me personally as I am not subscribed 
to util-linux-ng.

Hi!

Since I do not dare to break kernel code[1], I try the same with userspace 
code. The following patch should add SCHED_IDLE support to chrt. Beware it is 
complety untested, since I get:

ms@mango> autoconf      ~/lokal/Kernel/Dokumentation/util-linux-ng
configure.ac:7: error: possibly undefined macro: AM_INIT_AUTOMAKE
      If this token and others are legitimate, please use m4_pattern_allow.
      See the Autoconf documentation.
configure.ac:37: error: possibly undefined macro: AM_CONDITIONAL
configure.ac:190: error: possibly undefined macro: AM_GNU_GETTEXT_VERSION
configure.ac:191: error: possibly undefined macro: AM_GNU_GETTEXT
ms@mango> ./configure      ~/lokal/Kernel/Dokumentation/util-linux-ng
configure: error: cannot find install-sh or install.sh in config "."/config

when trying to compile util-linux-ng from GIT. (Note: I have no glue about 
autoconf, I only ever started an pre-existing ./configure script). I tried 
with autoconf 2.61-8 from Debian Lenny.

I will test this commit if someone gives me a hint on how to compile 
util-linux-ng.

[1] http://marc.info/?l=linux-kernel&m=122217132330769&w=2

---
From 8c6c5154bc5b53c0ccad8faa0ee3fe07bae447a5 Mon Sep 17 00:00:00 2001
From: Martin Steigerwald <ms@xxxxxxxxx>
Date: Tue, 23 Sep 2008 14:23:03 +0200
Subject: [PATCH] Support CFS SCHED_IDLE priority and document it

Support CFS_SCHED_IDLE priority and document it.

Beware, this is completely untested, since I autoconf 2.61-8 from Debian
Lenny produced errors.

Signed-off-by: Martin Steigerwald <ms@xxxxxxxxx>
---
 schedutils/chrt.1 |   11 +++++++++--
 schedutils/chrt.c |   23 +++++++++++++++++++++++
 2 files changed, 32 insertions(+), 2 deletions(-)

diff --git a/schedutils/chrt.1 b/schedutils/chrt.1
index dbc2958..67a9421 100644
--- a/schedutils/chrt.1
+++ b/schedutils/chrt.1
@@ -45,13 +45,16 @@ runs COMMAND with the given attributes.  Both policy (one 
of
 .BR SCHED_OTHER ,
 .BR SCHED_FIFO ,
 .BR SCHED_RR ,
+.BR SCHED_BATCH,
 or
-.BR SCHED_BATCH )
+.BR SCHED_IDLE)
 and priority can be set and retrieved.
 .PP
 The
 .BR SCHED_BATCH
-policy is supported since Linux 2.6.16.
+policy is supported since Linux 2.6.16. The
+.BR SCHED_IDLE
+policy is supported since Linux 2.6.23.
 .SH OPTIONS
 .TP
 .B -p, --pid
@@ -65,6 +68,10 @@ set scheduling policy to
 set scheduling policy to
 .BR SCHED_FIFO
 .TP
+.B -i, --idle
+set schedulng policy to
+.BR SCHED_IDLE
+.TP
 .B -m, --max
 show minimum and maximum valid priorities, then exit
 .TP
diff --git a/schedutils/chrt.c b/schedutils/chrt.c
index ba07dbe..5da8f6b 100644
--- a/schedutils/chrt.c
+++ b/schedutils/chrt.c
@@ -35,6 +35,14 @@
 # define SCHED_BATCH 3
 #endif
 
+/* the SCHED_IDLE is supported since Linux 2.6.23
+ * commit id 0e6aca43e08a62a48d6770e9a159dbec167bf4c6
+ * -- temporary workaround for people with old glibc headers
+ */
+#ifndef SCHED_IDLE
+# define SCHED_IDLE 5
+#endif
+
 static void show_usage(const char *cmd)
 {
 	fprintf(stderr, "chrt (%s)\n", PACKAGE_STRING);
@@ -45,6 +53,8 @@ static void show_usage(const char *cmd)
 			"set policy to SCHED_BATCH\n");
 	fprintf(stderr, "  -f, --fifo                         "
 			"set policy to SCHED_FIFO\n");
+	fprintf(stderr, "  -i, --idle                         "
+			"set policy to SCHED_IDLE\n");
 	fprintf(stderr, "  -p, --pid                          "
 			"operate on existing given pid\n");
 	fprintf(stderr, "  -m, --max                          "
@@ -87,6 +97,8 @@ static void show_rt_info(const char *what, pid_t pid)
 	case SCHED_FIFO:
 		printf("SCHED_FIFO\n");
 		break;
+	case SCHED_IDLE:
+		printf("SCHED_IDLE\n");
 	case SCHED_RR:
 		printf("SCHED_RR\n");
 		break;
@@ -138,6 +150,13 @@ static void show_min_max(void)
 		printf("SCHED_BATCH min/max priority\t: %d/%d\n", min, max);
 	else
 		printf("SCHED_BATCH not supported?\n");
+
+	max = sched_get_priority_max(SCHED_IDLE);
+	min = sched_get_priority_min(SCHED_IDLE);
+	if (max >= 0 && min >= 0)
+		printf("SCHED_IDLE min/max priority\t: %d/%d\n", min, max);
+	else
+		printf("SCHED_IDLE not supported?\n");
 }
 
 int main(int argc, char *argv[])
@@ -149,6 +168,7 @@ int main(int argc, char *argv[])
 	struct option longopts[] = {
 		{ "batch",	0, NULL, 'b' },
 		{ "fifo",	0, NULL, 'f' },
+		{ "idle",	0, NULL, 'i' },
 		{ "pid",	0, NULL, 'p' },
 		{ "help",	0, NULL, 'h' },
 		{ "max",        0, NULL, 'm' },
@@ -170,6 +190,9 @@ int main(int argc, char *argv[])
 		case 'f':
 			policy = SCHED_FIFO;
 			break;
+		case 'i':
+			policy = SCHED_IDLE;
+			break;
 		case 'm':
 			show_min_max();
 			return 0;

-- 
Martin Steigerwald - team(ix) GmbH - http://www.teamix.de
gpg: 19E3 8D42 896F D004 08AC A0CA 1E10 C593 0399 AE90

Attachment: signature.asc
Description: This is a digitally signed message part.


[Index of Archives]     [Netdev]     [Ethernet Bridging]     [Linux Wireless]     [Kernel Newbies]     [Security]     [Linux for Hams]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux Admin]     [Samba]

  Powered by Linux