[RFC PATCH 0/4] arm64: vdso: check whether the params is invalid address

Will Deacon will.deacon at arm.com
Wed Jun 8 02:33:20 PDT 2016


On Wed, Jun 08, 2016 at 05:18:26PM +0800, Yang Yingliang wrote:
> 
> 
> On 2016/6/7 1:12, Will Deacon wrote:
> >On Wed, Jun 01, 2016 at 11:05:58AM +0800, Yang Yingliang wrote:
> >>The params of gettimeofday(), clock_gettime() and clock_getres()
> >>is not checked. This will cause segment faults when the address is
> >>invalid.
> >>E.g. gettimeofday(-1, -1);
> >>      clock_gettime(0, -1);
> >>      clock_getres(0, -1);
> >>This patchset add a macro and use it to check the validation of these
> >>pointer params.
> >
> >Is this really necessary? It doesn't look to me like other architectures
> >bother with this, and you're just adding code to the fastpath to handle
> >cases that shouldn't happen to start with.
> I agree.
> 
> I find clock_gettime() don't check if tp is NULL. I think it need a
> checking like clock_getres().
> 
> What's your suggestion ?

So what? If you pass NULL then you get a SEGV. Just like if you pass a
NULL pointer to various glibc wrappers.

Don't pass NULL. Problem solved.

Will



More information about the linux-arm-kernel mailing list