[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20070518073147.GC28702@elte.hu>
Date: Fri, 18 May 2007 09:31:47 +0200
From: Ingo Molnar <mingo@...e.hu>
To: Bill Huey <billh@...ppy.monkey.org>
Cc: linux-kernel@...r.kernel.org,
Linus Torvalds <torvalds@...ux-foundation.org>,
Andrew Morton <akpm@...ux-foundation.org>,
Con Kolivas <kernel@...ivas.org>,
Nick Piggin <npiggin@...e.de>, Mike Galbraith <efault@....de>,
Arjan van de Ven <arjan@...radead.org>,
Peter Williams <pwil3058@...pond.net.au>,
Thomas Gleixner <tglx@...utronix.de>, caglar@...dus.org.tr,
Willy Tarreau <w@....eu>,
Gene Heskett <gene.heskett@...il.com>, Mark Lord <lkml@....ca>,
William Lee Irwin III <wli@...omorphy.com>
Subject: Re: [patch] CFS scheduler, -v12
* Bill Huey <billh@...ppy.monkey.org> wrote:
> On Sun, May 13, 2007 at 05:38:53PM +0200, Ingo Molnar wrote:
> > Even a simple 3D app like glxgears does a sys_sched_yield() for
> > every frame it generates (!) on certain 3D cards, which in essence
> > punishes any scheduler that implements sys_sched_yield() in a sane
> > manner. This interaction of CFS's yield implementation with this
> > user-space bug could be the main reason why some testers reported SD
> > to be handling 3D games better than CFS. (SD uses a yield
> > implementation similar to the vanilla scheduler.)
> >
> > So i've added a yield workaround to -v12, which makes it work
> > similar to how the vanilla scheduler and SD does it. (Xorg has been
> > notified and this bug should be fixed there too. This took some time
> > to debug because the 3D driver i'm using for testing does not use
> > sys_sched_yield().) The workaround is activated by default so -v12
> > should work 'out of the box'.
>
> This is an incorrect analysis. [...]
i'm puzzled, incorrect in specifically what way?
> [...] OpenGL has the ability to "yield" after every frame specifically
> for SGI IRIX (React/Pro) frame scheduler (driven by the system
> vertical retrace interrupt) so that it can free up CPU resources for
> other tasks to run. [...]
what you say makes no sense to me. The majority of Linux 3D apps are
already driven by the vertical retrace interrupt and properly 'yield the
CPU' if they wish so, but this has nothing to do with sys_sched_yield().
> The correct solution is for the app to use a directed yield and a
> policy that can directly support it so that OpenGL can guaratee a
> frame rate governed by CPU bandwidth allocated by the scheduler.
>
> Will is working on such a mechanism now.
i'm even more puzzled. I've added sched_yield_to() to CFS -v6 and it's
been part of CFS since then. I'm curious, on what mechanism is Will
working and have any patches been sent to lkml for discussion?
Ingo
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists