[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <544E59DC.3060906@oracle.com>
Date: Mon, 27 Oct 2014 10:42:36 -0400
From: Sasha Levin <sasha.levin@...cle.com>
To: David Miller <davem@...emloft.net>
CC: a.ryabinin@...sung.com, pablo@...filter.org, mschmidt@...hat.com,
akpm@...ux-foundation.org, linux-kernel@...r.kernel.org,
netdev@...r.kernel.org
Subject: Re: [PATCH] netlink: don't copy over empty attribute data
On 10/26/2014 10:03 PM, David Miller wrote:
> From: Sasha Levin <sasha.levin@...cle.com>
> Date: Sun, 26 Oct 2014 19:32:42 -0400
>
>> How so? GCC states clearly that you should *never* pass a NULL
>> pointer there:
>>
>> "The pointers passed to memmove (and similar functions in <string.h>) must
>> be non-null even when nbytes==0" (https://gcc.gnu.org/gcc-4.9/porting_to.html).
>>
>> Even if it doesn't dereference it, it can break somehow in a subtle way. Leaving
>> the kernel code assuming that gcc (or any other compiler) would always behave
>> the same in a situation that shouldn't occur.
>
> Show me a legal way in which one could legally dereference the pointer
> when length is zero, and I'll entertain this patch.
The moment you've triggered an undefined behaviour you have GCC license to
dereference anything it wants. GCC would be well within it's rights
dereferencing a NULL "from".
They even state it clearly in that GCC 4.9 porting guide I've linked above:
"""
Calling copy(p, NULL, 0) can therefore deference a null pointer and crash.
The example above needs to be fixed to avoid the invalid memmove call, for example:
if (nbytes != 0)
memmove (dest, src, nbytes);
"""
Thanks,
Sasha
--
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