Re: [PATCH] x86: suppress sparse warning in copy_to_user()

From: Johannes Berg
Date: Tue Oct 04 2016 - 04:49:18 EST



> > > If that was the case, everyone should have seen such warnings
> > > from the day the original patch got introduced.Â
> >
> > Only if they run sparse. Clearly people don't, or we wouldn't have
> > a history of a ton of such problems, e.g.
>
> No - you say "which gcc declares with (void *, int type) prototype".
> If that was the case, there would need to be a warning.

There would need to be a warning when?

> > > And the compiler warnings
> > > I get when testing with all four combinations of const and
> > > volatile
> > > also supports this by saying "expected 'const void *' but ..."Â
> >
> > It's not a compiler warning though that I'm getting.
> >
> > What tool are you using to get such a warning?
>
> I'm talking about gcc and the warning surfacing when I additonally
> add volatile.

Oh, sorry. If you get the warning, it prints "expected 'const void *'"
... yeah, I see.

> > https://gcc.gnu.org/onlinedocs/gcc/Object-Size-Checking.htmlÂ;
>
> Perhaps it's just the documentation which is imprecise here?

Hmm, yeah, that could be right, or maybe it changed at some point?

If it were defined the way the documentation says, you should have
gotten a compiler warning ("passing argument 1 ... discards âconstâ
qualifier from pointer target type") with the code as it is (without my
patch), since you can't pass a const pointer to a function that expects
a non-const pointer. Clearly that didn't happen.

That does indicate that the prototype is indeed with the const, I guess
I'll go fix sparse instead.

Sorry I misread your earlier explanation entirely!

johannes