Re: [PATCH] [4/4] SCHED: Use a lookup array in sd_level_to_string

From: Ingo Molnar
Date: Wed Nov 12 2008 - 13:43:43 EST



* Johannes Weiner <hannes@xxxxxxxxxxx> wrote:

> On Wed, Nov 12, 2008 at 01:45:12PM +0100, Andi Kleen wrote:
> >
> > Generates better/shorter code. Doesn't matter much because it's only
> > a SCHED_DEBUG function.
> >
> > Signed-off-by: Andi Kleen <ak@xxxxxxxxxxxxxxx>
> >
> > ---
> > kernel/sched.c | 29 +++++++++++------------------
> > 1 file changed, 11 insertions(+), 18 deletions(-)
> >
> > Index: linux-2.6.28-rc4-test/kernel/sched.c
> > ===================================================================
> > --- linux-2.6.28-rc4-test.orig/kernel/sched.c 2008-11-12 12:36:23.000000000 +0100
> > +++ linux-2.6.28-rc4-test/kernel/sched.c 2008-11-12 12:43:58.000000000 +0100
> > @@ -6629,24 +6629,17 @@
> >
> > static inline const char *sd_level_to_string(enum sched_domain_level lvl)
> > {
> > - switch (lvl) {
> > - case SD_LV_NONE:
> > - return "NONE";
> > - case SD_LV_SIBLING:
> > - return "SIBLING";
> > - case SD_LV_MC:
> > - return "MC";
> > - case SD_LV_CPU:
> > - return "CPU";
> > - case SD_LV_NODE:
> > - return "NODE";
> > - case SD_LV_ALLNODES:
> > - return "ALLNODES";
> > - case SD_LV_MAX:
> > - return "MAX";
> > -
> > - }
> > - return "MAX";
> > + static const char *lva[] = {
> > +#define T(x) [SD_LV_ ## x ] = #T
>
> Shouldn't ^ that be x?

hasnt been tested i guess. Note that the patch is moot: an equivalent
change has been done in the scheduler tree already, in a cleaner way.
It's all in linux-next.

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