summaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@woody.linux-foundation.org>2008-01-22 18:18:45 +0100
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2008-01-22 18:18:45 +0100
commitb2214fca2bf7db492cd508769da7ca703a7f1806 (patch)
treeee7103a0d53f11213a8ea25aed37b50c2cab464b /kernel
parentrcu: fix section mismatch (diff)
parentsched: group scheduler, set uid share fix (diff)
downloadlinux-b2214fca2bf7db492cd508769da7ca703a7f1806.tar.xz
linux-b2214fca2bf7db492cd508769da7ca703a7f1806.zip
Merge git://git.kernel.org/pub/scm/linux/kernel/git/mingo/linux-2.6-sched
* git://git.kernel.org/pub/scm/linux/kernel/git/mingo/linux-2.6-sched: sched: group scheduler, set uid share fix
Diffstat (limited to 'kernel')
-rw-r--r--kernel/sched.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/kernel/sched.c b/kernel/sched.c
index 37cf07aa4164..e76b11ca6df3 100644
--- a/kernel/sched.c
+++ b/kernel/sched.c
@@ -7153,6 +7153,14 @@ int sched_group_set_shares(struct task_group *tg, unsigned long shares)
{
int i;
+ /*
+ * A weight of 0 or 1 can cause arithmetics problems.
+ * (The default weight is 1024 - so there's no practical
+ * limitation from this.)
+ */
+ if (shares < 2)
+ shares = 2;
+
spin_lock(&tg->lock);
if (tg->shares == shares)
goto done;