Re: [PATCH] Fix cpuset sched_relax_domain_level control file

From: Adrian Bunk
Date: Wed May 07 2008 - 05:49:43 EST


On Tue, May 06, 2008 at 06:41:39PM -0700, Paul Menage wrote:
> On Tue, May 6, 2008 at 6:38 PM, Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> wrote:
> > On Tue, 06 May 2008 18:08:17 -0700 Paul Menage <menage@xxxxxxxxxx> wrote:
> >
> > > -static int update_relax_domain_level(struct cpuset *cs, char *buf)
> > > +static int update_relax_domain_level(struct cpuset *cs, s64 val)
> > > {
> > > - int val = simple_strtol(buf, NULL, 10);
> > > -
> > > - if (val < 0)
> > > + if ((int)val < 0)
> > > val = -1;
> > >
> >
> > Are you sure about the typecast here? If `val' has a value of say
> > 0x0000_ffff_ffff_ffff then I assume the casted value will be negative, only
> > it wasn't?
>
> It seems like the simplest approach - if it's outside the range of a
> positive int, set it to -1.

That's very hard to understand for someone who looks at the code - and
being able to understand the code is much more important than the
number of characters in the source code.

If you'd write something like

if ((val < 0) || (val > INT_MAX))

instead it would be obvious for the reader what's happening here, and
that this was intended.

> Paul

cu
Adrian

BTW: I have seen that even further restrictions are discussed in this
case, my comment is more about the general readability of this
"simplest approach".

--

"Is there not promise of rain?" Ling Tan asked suddenly out
of the darkness. There had been need of rain for many days.
"Only a promise," Lao Er said.
Pearl S. Buck - Dragon Seed

--
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/