From: Zhang Zhen <zhenzhang.zhang@huawei.com>
To: Geert Uytterhoeven <geert@linux-m68k.org>
Cc: Hu Jianyang <hujianyang@huawei.com>,
MTD Maling List <linux-mtd@lists.infradead.org>,
adrian.hunter@intel.com, Artem Bityutskiy <dedekind1@gmail.com>
Subject: Re: [PATCH] ubi: replace simple_strtoul() with kstrtoul()
Date: Tue, 20 May 2014 09:18:38 +0800 [thread overview]
Message-ID: <537AAD6E.6020806@huawei.com> (raw)
In-Reply-To: <CAMuHMdVyVyKifhntPBeFS893MfkugYsMpKOizfDD8CqzPP96vQ@mail.gmail.com>
On 2014/5/19 17:14, Geert Uytterhoeven wrote:
> Please don't add mindless casts!
>
> On Mon, May 19, 2014 at 10:38 AM, Zhang Zhen <zhenzhang.zhang@huawei.com> wrote:
>> --- a/drivers/mtd/ubi/build.c
>> +++ b/drivers/mtd/ubi/build.c
>> @@ -1190,10 +1190,13 @@ static struct mtd_info * __init open_mtd_by_chdev(const char *mtd_dev)
>> static struct mtd_info * __init open_mtd_device(const char *mtd_dev)
>> {
>> struct mtd_info *mtd;
>> - int mtd_num;
>> + int mtd_num, ret;
>> char *endp;
>>
>> - mtd_num = simple_strtoul(mtd_dev, &endp, 0);
>> + endp = (char *)mtd_dev;
>> + ret = kstrtoul(endp, 0, (unsigned long *)&mtd_num);
>
> On 64-bit, long is 64-bit, hence this will write beyond mtd_num and will corrupt
> the stack.
Yeah, you are right. This really may write beyond dev.
The kstrtoul(const char *s, unsigned int base, unsigned long *res) only accept unsigned long
pointer as the third parameter.
And the original function simple_strtoul() returns unsigned long type value.
It is also cast. So this may not corrupt the stack.
Or do you have any better suggestion about this?
Thanks.
>
> Gr{oetje,eeting}s,
>
> Geert
>
> --
> Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@linux-m68k.org
>
> In personal conversations with technical people, I call myself a hacker. But
> when I'm talking to journalists I just say "programmer" or something like that.
> -- Linus Torvalds
>
>
next prev parent reply other threads:[~2014-05-20 1:19 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <1400488570-20288-1-git-send-email-zhenzhang.zhang@huawei.com>
2014-05-19 8:38 ` [PATCH] ubi: replace simple_strtoul() with kstrtoul() Zhang Zhen
2014-05-19 9:14 ` Geert Uytterhoeven
2014-05-20 1:18 ` Zhang Zhen [this message]
2014-05-20 6:57 ` Geert Uytterhoeven
2014-05-20 8:14 ` Zhang Zhen
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=537AAD6E.6020806@huawei.com \
--to=zhenzhang.zhang@huawei.com \
--cc=adrian.hunter@intel.com \
--cc=dedekind1@gmail.com \
--cc=geert@linux-m68k.org \
--cc=hujianyang@huawei.com \
--cc=linux-mtd@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.