[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1265059030.25140.349.camel@Joe-Laptop.home>
Date: Mon, 01 Feb 2010 13:17:10 -0800
From: Joe Perches <joe@...ches.com>
To: Tony Lindgren <tony@...mide.com>
Cc: d binderman <dcb314@...mail.com>, linux-kernel@...r.kernel.org
Subject: Re: arch/arm/mach-omap2/mux.c: Off by one error
On Mon, 2010-02-01 at 13:06 -0800, Tony Lindgren wrote:
> * d binderman <dcb314@...mail.com> [100131 04:14]:
> > I just ran the sourceforge tool cppcheck over the source code of the
> > new Linux kernel 2.6.33-rc6
> >
> > It said
> >
> > [./arm/mach-omap2/mux.c:492]: (error) Buffer access out-of-bounds
> >
> > The source code is
> >
> > char mode[14];
> > int i = -1;
> >
> > sprintf(mode, "OMAP_MUX_MODE%d", val & 0x7);
> > 13 characters + 1 digit + 1 zero byte is more than 14 characters.
> > Suggest new code
> > char mode[15];
> diff --git a/arch/arm/mach-omap2/mux.c b/arch/arm/mach-omap2/mux.c
> index 32764be..047aa57 100644
> --- a/arch/arm/mach-omap2/mux.c
> +++ b/arch/arm/mach-omap2/mux.c
> @@ -486,7 +486,7 @@ int __init omap_mux_init_signal(char *muxname, int val)
> static inline void omap_mux_decode(struct seq_file *s, u16 val)
> {
> char *flags[OMAP_MUX_MAX_NR_FLAGS];
> - char mode[14];
> + char mode[15];
Maybe:
char mode[sizeof("OMAP_MUX_MODE") + 1];
or
char mode[OMAP_MUX_DEFNAME_LEN];
with the #define moved up a bit?
--
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