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

From: Chen Gang
Date: Wed Apr 10 2013 - 02:01:15 EST


On 2013å04æ09æ 17:36, Chen Gang wrote:
> On 2013å04æ09æ 09:52, Chen Gang wrote:
>>>>>
>>>>> it looks like a bug. for me, I prefer to give length check for it.
>>>>>
>>>>> but I am sorry, now, I can not be sure whether it is really a bug.
>>> It really is. We don't export any symbols > 128 characters, but if we
>>> did then kallsyms_expand_symbol() would overflow the buffer handed to
>>> it.
>>>
>>> Your suggestion about an explicit length for kallsyms_expand_symbol() is
>>> the correct one.
>>
>>

after have a test, what you said above is correct.


it is my fault:
the scripts/kallsyms.c use KSYM_NAME_LEN (also defined as 128).
but this macro is not for symbol name (it is for token name !!).
its symbol max length is 500 (use hard code number, no comments)

if symbol name length is not less than 128, kernel need check it.
I made a driver to call function kallsyms_on_each_symbol.
also add a patch to check the length in kernel.
it really has effect.
System.map still has the full symbol name when len >= 128.
kallsyms_on_each_symbol truncates the name to 127, when len >= 128

I will send the related patch.
can I mark you as Signed-of-by too (you find and be sure about it) ?


:-)


gchen.

>
> oh, sorry, after read the related source code, I think:
>
> for kernel/kallsyms.c, it is no issue
> (although I still also prefer to give a length checking).
>
> the reason is:
> scripts/kallsyms.c does not check the 128 limitation.
> if compiler limits it with 128 automatically, we will have no issue.
> else the scripts/kallsyms will cause issue.
>
> so whether what happens, kernel/kallsyms.c will not cause issue.
>
> :-)
>
>
> the related patch for scripts/kallsyms.c is below, please check, thanks.
> (now, it is just for a reference, after have a test, I will send).
>
>
> -----------------------patch begin--------------------------------------
>
> diff --git a/scripts/kallsyms.c b/scripts/kallsyms.c
> index 487ac6f..9ec6d1f 100644
> --- a/scripts/kallsyms.c
> +++ b/scripts/kallsyms.c
> @@ -145,13 +145,15 @@ static int read_symbol(FILE *in, struct sym_entry *s)
> /* include the type field in the symbol name, so that it gets
> * compressed together */
> s->len = strlen(str) + 1;
> + if (s->len > KSYM_NAME_LEN)
> + s->len = KSYM_NAME_LEN;
> s->sym = malloc(s->len + 1);
> if (!s->sym) {
> fprintf(stderr, "kallsyms failure: "
> "unable to allocate required amount of memory\n");
> exit(EXIT_FAILURE);
> }
> - strcpy((char *)s->sym + 1, str);
> + strlcpy((char *)s->sym + 1, str, KSYM_NAME_LEN);
> s->sym[0] = stype;
>
> return 0;
> @@ -290,7 +292,7 @@ static void write_src(void)
> unsigned int i, k, off;
> unsigned int best_idx[256];
> unsigned int *markers;
> - char buf[KSYM_NAME_LEN];
> + char buf[KSYM_NAME_LEN + 1];
>
> printf("#include <asm/types.h>\n");
> printf("#if BITS_PER_LONG == 64\n");
>


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