+ timer-add-an-initial-05s-delay-to-calc_load.patch added to -mm tree

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

 



The patch titled
     timer: add an initial 0.5s delay to calc_load
has been added to the -mm tree.  Its filename is
     timer-add-an-initial-05s-delay-to-calc_load.patch

*** Remember to use Documentation/SubmitChecklist when testing your code ***

See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find
out what to do about this

------------------------------------------------------
Subject: timer: add an initial 0.5s delay to calc_load
From: Simon Arlott <simon@xxxxxxxxxxx>

This adds an initial 0.5s delay to calc_load so that it avoids updating
load at the same time as tasks scheduled using round_jiffies, otherwise the
load average is badly affected by tasks that run every time calc_load does
(currently every 5s).

I'm assuming this change doesn't affect the intention of round_jiffies, to
avoid tasks waking the cpu at different times, because calc_load is already
run very often by a call from update_times(ticks) on every timer interrupt.

Without this change or an appropriate equivalent, my change to cxacru
causes the load to stay around 1.00 even when mostly idle since it now
runs every second using round_jiffies:
> [  332.416288] cxacru_poll_status(..), jiffies=5000 [start]
> [  332.417312] calc_load(1), count=-1, jiffies=5001 [start]
> [  332.417322] calc_load(1), count=4999, jiffies=5001 [finish]
> [  332.423382] cxacru_poll_status(..), jiffies=5007, next=993 [finish]

Signed-off-by: Simon Arlott <simon@xxxxxxxxxxx>
Cc: Arjan van de Ven <arjan@xxxxxxxxxxxxxxx>
Cc: Ingo Molnar <mingo@xxxxxxx>
Cc: Thomas Gleixner <tglx@xxxxxxxxxxxxx>
Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx>
---

 kernel/timer.c |    2 +-
 1 files changed, 1 insertion(+), 1 deletion(-)

diff -puN kernel/timer.c~timer-add-an-initial-05s-delay-to-calc_load kernel/timer.c
--- a/kernel/timer.c~timer-add-an-initial-05s-delay-to-calc_load
+++ a/kernel/timer.c
@@ -1226,7 +1226,7 @@ EXPORT_SYMBOL(avenrun);
 static inline void calc_load(unsigned long ticks)
 {
 	unsigned long active_tasks; /* fixed-point */
-	static int count = LOAD_FREQ;
+	static int count = LOAD_FREQ + HZ/2;
 
 	count -= ticks;
 	if (unlikely(count < 0)) {
_

Patches currently in -mm which might be from simon@xxxxxxxxxxx are

usbatm-create-sysfs-link-device-from-atm-class-device.patch
cxacru-export-detailed-device-info-through-sysfs-updated.patch
maintainers-add-myself-for-cxacru-in-drivers-usb-atm.patch
timer-add-an-initial-05s-delay-to-calc_load.patch

-
To unsubscribe from this list: send the line "unsubscribe mm-commits" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Kernel Newbies FAQ]     [Kernel Archive]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [Bugtraq]     [Photo]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]

  Powered by Linux