Re: 2.4.4 sluggish under fork load

From: Peter Osterlund (peter.osterlund@mailbox.swipnet.se)
Date: Sun Apr 29 2001 - 03:26:57 EST


On Sat, 28 Apr 2001, Linus Torvalds wrote:

> > could we leave it at half, but set the parent to SCHED_YIELD?
>
> Sounds like a good idea. Peter, how does that feel to you? I bet that I'v
> enever seen it simply because all my machines are (a) much too powerful
> for any reasonable use and (b) SMP.

That seems to work. The scheduling delays are back to 20ms and the
sluggishness feeling is gone. I wrote a simple test program to verify that
the child is still scheduled before the parent, so the performance
advantage should still be there. The only annoying thing is that it hides
the bash bug ;)

Patch below:

--- linux-2.4.4.orig/kernel/fork.c Sat Apr 28 10:17:00 2001
+++ linux-2.4.4/kernel/fork.c Sun Apr 29 10:06:42 2001
@@ -666,16 +666,18 @@
         p->pdeath_signal = 0;

         /*
- * Give the parent's dynamic priority entirely to the child. The
- * total amount of dynamic priorities in the system doesn't change
- * (more scheduling fairness), but the child will run first, which
- * is especially useful in avoiding a lot of copy-on-write faults
- * if the child for a fork() just wants to do a few simple things
- * and then exec(). This is only important in the first timeslice.
- * In the long run, the scheduling behavior is unchanged.
+ * "share" dynamic priority between parent and child, thus the
+ * total amount of dynamic priorities in the system doesn't change,
+ * more scheduling fairness. The parent yields to let the child run
+ * first, which is especially useful in avoiding a lot of
+ * copy-on-write faults if the child for a fork() just wants to do a
+ * few simple things and then exec(). This is only important in the
+ * first timeslice. In the long run, the scheduling behavior is
+ * unchanged.
          */
- p->counter = current->counter;
- current->counter = 0;
+ p->counter = (current->counter + 1) >> 1;
+ current->counter >>= 1;
+ current->policy |= SCHED_YIELD;
         current->need_resched = 1;

         /*

-- 
Peter Österlund             peter.osterlund@mailbox.swipnet.se
Sköndalsvägen 35            http://home1.swipnet.se/~w-15919
S-128 66 Sköndal            +46 8 942647
Sweden

- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/



This archive was generated by hypermail 2b29 : Mon Apr 30 2001 - 21:00:21 EST