[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20090623024337.GC3620@redhat.com>
Date: Mon, 22 Jun 2009 22:43:37 -0400
From: Vivek Goyal <vgoyal@...hat.com>
To: Fabio Checconi <fchecconi@...il.com>
Cc: Balbir Singh <balbir@...ux.vnet.ibm.com>,
linux-kernel@...r.kernel.org,
containers@...ts.linux-foundation.org, dm-devel@...hat.com,
jens.axboe@...cle.com, nauman@...gle.com, dpshah@...gle.com,
lizf@...fujitsu.com, mikew@...gle.com, paolo.valente@...more.it,
ryov@...inux.co.jp, fernando@....ntt.co.jp, s-uchida@...jp.nec.com,
taka@...inux.co.jp, guijianfeng@...fujitsu.com, jmoyer@...hat.com,
dhaval@...ux.vnet.ibm.com, righi.andrea@...il.com,
m-ikeda@...jp.nec.com, jbaron@...hat.com, agk@...hat.com,
snitzer@...hat.com, akpm@...ux-foundation.org, peterz@...radead.org
Subject: Re: [PATCH 02/20] io-controller: Common flat fair queuing code in
elevaotor layer
On Mon, Jun 22, 2009 at 02:43:13PM +0200, Fabio Checconi wrote:
[..]
> > > +/**
> > > + * bfq_first_active - find the eligible entity with the smallest finish time
> > > + * @st: the service tree to select from.
> > > + *
> > > + * This function searches the first schedulable entity, starting from the
> > > + * root of the tree and going on the left every time on this side there is
> > > + * a subtree with at least one eligible (start <= vtime) entity. The path
> > > + * on the right is followed only if a) the left subtree contains no eligible
> > > + * entities and b) no eligible entity has been found yet.
> > > + */
> > > +static struct io_entity *bfq_first_active_entity(struct io_service_tree *st)
> > > +{
> > > + struct io_entity *entry, *first = NULL;
> > > + struct rb_node *node = st->active.rb_node;
> > > +
> > > + while (node != NULL) {
> > > + entry = rb_entry(node, struct io_entity, rb_node);
> > > +left:
> > > + if (!bfq_gt(entry->start, st->vtime))
> > > + first = entry;
> > > +
> > > + BUG_ON(bfq_gt(entry->min_start, st->vtime));
> > > +
> > > + if (node->rb_left != NULL) {
> > > + entry = rb_entry(node->rb_left,
> > > + struct io_entity, rb_node);
> > > + if (!bfq_gt(entry->min_start, st->vtime)) {
> > > + node = node->rb_left;
> > > + goto left;
> > > + }
> > > + }
> > > + if (first != NULL)
> > > + break;
> > > + node = node->rb_right;
> >
> > Please help me understand this, we sort the tree by finish time, but
> > search by vtime, start_time. The worst case could easily be O(N),
> > right?
> >
>
> no, (again, the full answer is in the paper); the nice property of
> min_start is that it partitions the tree in two regions, one with
> eligible entities and one without any of them. once we know that
> there is one eligible entity (checking the min_start at the root)
> we can find the node i with min(F_i) subject to S_i < V walking down
> a single path from the root to the leftmost eligible entity. (we
> need to go to the right only if the subtree on the left contains
> no eligible entities at all.) since the RB tree is balanced this
> can be done in O(log N).
>
Hi Fabio,
When I go thorough the paper you mentioned above, they seem to have
sorted the tree based on eligible time (looks like equivalent of start
time) and then keep track of minimum deadline on each node (equivalnet of
finish time).
We seem to be doing reverse in BFQ where we sort tree on finish time
and keep track of minimum start time on each node. Is there any specific
reason behind that?
Thanks
Vivek
--
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