Daniel Walker wrote:
George,
I wanted to show you the code below, from the RT patch. I think
it's possible that, if the code isn't changed in the way below, the
while() loop could run forever. If jiffies is very fast moving , and the
softirqd is low priority. Do you have any comments on this?
What you are saying is that it is possible that the kernel will not be able to
keep up the timer list if we lower its priority. Making this change just allows
softirqd to do other things and come right back to this code. If we care at all
about timers, we should do a better job of setting priorities.
In the end, I think we will want to go to a system where timers are just moved
to an expired list on the jiffie interrupt (this is very fast except for the
cascade, as the whole list is moved in one operation). The expired list would
then be processed by a dedicated timer delivery thread that shifts its priority
to match the priority of the highest priority pending timer.
Thomas Gleixner (added to the cc) is currently working on just such a change.
So, in short, I don't see the point to the suggested change. If the kernel is
late, it is best to let it catch up as fast as it can by looping here. The only
counter argument that makes sense to me it that in this case we are starving
other softirqd driven tasks, but that should, if any thing, lighten the timer
load and let this complete faster.
George
--
Daniel
@@ -436,13 +437,30 @@ static int cascade(tvec_base_t *base, tv
static inline void __run_timers(tvec_base_t *base)
{
struct timer_list *timer;
+ unsigned long jiffies_sample = jiffies;
spin_lock_irq(&base->lock);
- while (time_after_eq(jiffies, base->timer_jiffies)) {
+ while (time_after_eq(jiffies_sample, base->timer_jiffies)) {
struct list_head work_list = LIST_HEAD_INIT(work_list);
struct list_head *head = &work_list;
int index = base->timer_jiffies & TVR_MASK;
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
--
George Anzinger [email protected]
HRT (High-res-timers): http://sourceforge.net/projects/high-res-timers/
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]