Re: [PATCH] kernel: module: strncpy issue, using strlcpy insteadof strncpy

From: Chen Gang
Date: Sun Apr 07 2013 - 23:03:07 EST


On 2013å04æ08æ 10:48, Chen Gang wrote:
> On 2013å04æ07æ 22:28, Geert Uytterhoeven wrote:
>> On Sun, Apr 7, 2013 at 1:38 PM, Chen Gang <gang.chen@xxxxxxxxxxx> wrote:
>>>> ownername and namebuf are all NUL terminated string.
>>>>
>>>> need always let them ended by '\0'.
>>>>
>>>> Signed-off-by: Chen Gang <gang.chen@xxxxxxxxxxx>
>>>> ---
>>>> kernel/module.c | 4 ++--
>>>> 1 files changed, 2 insertions(+), 2 deletions(-)
>>>>
>>>> diff --git a/kernel/module.c b/kernel/module.c
>>>> index 3c2c72d..597efd8 100644
>>>> --- a/kernel/module.c
>>>> +++ b/kernel/module.c
>>>> @@ -3464,7 +3464,7 @@ const char *module_address_lookup(unsigned long addr,
>>>> }
>>>> /* Make a copy in here where it's safe */
>>>> if (ret) {
>>>> - strncpy(namebuf, ret, KSYM_NAME_LEN - 1);
>>>> + strlcpy(namebuf, ret, KSYM_NAME_LEN);
>>>> ret = namebuf;
>>>> }
>>>> preempt_enable();
>> Is this buffer ever copied to userspace?
>
>

the key words is:
if it knows the length of namebuf, it may need initialized namebuf.
if it can not know the length of namebuf
it can not initialize namebuf.
(in our case, it only know, the namebuf length >= KSYM_NAME_LEN)

so, it need not initialize it.

:-)

thanks.

gchen.


> at lease now:
> I think, it is not, the reason is:
> it is only a tool function for kallsyms using.
> it has no duty to let namebuf initialized.
>
> please reference the related comments in include/linux/module.h
>
> 493 /* For kallsyms to ask for address resolution. namebuf should be at
> 494 * least KSYM_NAME_LEN long: a pointer to namebuf is returned if
> 495 * found, otherwise NULL. */
> 496 const char *module_address_lookup(unsigned long addr,
> 497 unsigned long *symbolsize,
> 498 unsigned long *offset,
> 499 char **modname,
> 500 char *namebuf);
>
>
> originally:
> it will not cause issue (the upper caller has noticed it).
> but we really need let it '\0' ended within module_address_lookup.
> (so, maybe for subject: "strncpy issue" need be deleted)
>
>
> in the future:
> since it is an extern function, it can be used by others.
> since it is a tool function, it can not be used directly by user mode.
> according to the api definition:
> if it is necessary to initialize (such as return to user mode)
> the caller should perform it.
> if it is not necessary to initialize (not return to user mode)
> still prefer the caller to initialize it.
> but should understand if the caller will not initialize it.
> (if caller does not initialize it, it should not cause issue)
>
>
> thanks.
>
> :-)
>
>


--
Chen Gang

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