From: "Robert T. Johnson" <rtjohnso@eecs.berkeley.edu>
To: Linus Torvalds <torvalds@osdl.org>
Cc: Al Viro <viro@math.psu.edu>, Linux Kernel <linux-kernel@vger.kernel.org>
Subject: Re: Finding user/kernel pointer bugs [no html]
Date: 09 Jun 2004 21:48:17 -0700 [thread overview]
Message-ID: <1086842898.32053.380.camel@dooby.cs.berkeley.edu> (raw)
In-Reply-To: <Pine.LNX.4.58.0406092059030.2050@ppc970.osdl.org>
On Wed, 2004-06-09 at 21:10, Linus Torvalds wrote:
> On Wed, 9 Jun 2004, Robert T. Johnson wrote:
> >
> > Despite that, I found numerous bugs in seven drivers. Only one of these
> > drivers had any __user annotations, so sparse isn't able to provide any
> > meaningful results on these source files yet. Even worse, sparse missed
> > bugs in drivers/usb/core/devio.c:proc_control() even though that
> > function has been annotated (this is not the first time cqual has found
> > bugs in code audited by sparse).
>
> Hmm.. That code has not been sparse-cleaned up, and as of today sparse
> gives 34 lines of warnings for that file. I assume the two you refer to is
>
> drivers/usb/core/devio.c:561:40: warning: cast removes address space of expression
> drivers/usb/core/devio.c:581:39: warning: cast removes address space of expression
>
> and I assume those are the ones your thing finds too?
>
> So I wanted to point out that sparse hasn't missed anything. It's just
> that the USB people haven't fixed the things it has found yet ;)
Sorry about that mistake. I see now that the data field has a __user
annotation.
> > I didn't write any annotations in any
> > driver files -- just a few header files under include. I've already
> > submitted patches to fix these bugs. This is 1 1/2 days work, with
> > _very_ incomplete annotations.
>
> And part of the reason I much prefer the sparse approach of doing proper C
> types is that it's (a) the C way and (b) it documents what is up.
>
> What we do NOT want to have is to continue with these "implied rules".
> That's what caused the bugs in the first place. I really want the user
> pointers to be _explicit_, because not only does that mean that a stupid
> tool can figure it out with purely "local" knowledge, but more
> importantly, it means that a _programmer_ can figure it out with purely
> local knowledge.
>
> Now, I'm obviously biased, and hey, two tools are better than one. I just
> wanted to point out that your claim that "sparse missed bugs" just isn't
> true. What _is_ true is that there is quite a bit of non-fixed code out
> there.
I agree that documenting interfaces is good. Just because the tool can
infer things automatically doesn't mean they can't also be annotated --
it just means you can get results sooner. I also understand if you just
want to do it the C way.
QUESTION: Do you find it's difficult to figure out which fields of
structures should be declared __user? One feature you might find useful
to add to sparse is the following:
If a structure pointer is __user, but it has some pointer fields that
aren't declared __user, there's a good chance that there's a missing
annotation or something. This is a simplified version of a rule in
cqual, but I think you might be able to implement it purely locally in
sparse. It'd be a bit of a hack, but it might help you discover missing
annotations sooner. Without this, the following code passes sparse w/o
error:
struct foo { char __kernel * p; };
void func (struct foo __user * x)
{
struct foo y;
copy_from_user(&y, x, sizeof (y));
y.p[0] = 0;
}
Best,
Rob
next prev parent reply other threads:[~2004-06-10 4:48 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-06-10 3:31 Finding user/kernel pointer bugs [no html] Robert T. Johnson
2004-06-10 4:10 ` Linus Torvalds
2004-06-10 4:48 ` Robert T. Johnson [this message]
2004-06-10 14:46 ` Linus Torvalds
2004-06-10 16:57 ` viro
2004-06-10 15:07 ` Timothy Miller
2004-06-10 15:04 ` Linus Torvalds
2004-06-10 15:26 ` Timothy Miller
2004-06-10 4:49 ` viro
2004-06-10 5:20 ` Robert T. Johnson
2004-06-10 16:58 ` Greg KH
2004-06-10 17:27 ` David Brownell
2004-06-10 17:35 ` Greg KH
2004-06-10 17:54 ` Thomas Sailer
2004-06-10 18:34 ` Greg KH
2004-06-10 18:45 ` viro
2004-06-10 18:54 ` Greg KH
2004-06-10 19:10 ` Greg KH
2005-05-19 6:25 ` Greg KH
2004-06-10 19:14 ` viro
2005-05-19 6:25 ` viro
2004-06-10 19:32 ` Greg KH
2005-05-19 6:25 ` Greg KH
2004-06-10 19:38 ` viro
2005-05-19 6:25 ` viro
2004-06-10 20:28 ` Sam Ravnborg
2005-05-19 6:25 ` Sam Ravnborg
2004-06-10 20:48 ` Randy.Dunlap
2005-05-19 6:25 ` Randy.Dunlap
2004-06-11 17:21 ` Jean Delvare
2005-05-19 6:25 ` Jean Delvare
2004-06-11 17:59 ` Greg KH
2005-05-19 6:25 ` Greg KH
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1086842898.32053.380.camel@dooby.cs.berkeley.edu \
--to=rtjohnso@eecs.berkeley.edu \
--cc=linux-kernel@vger.kernel.org \
--cc=torvalds@osdl.org \
--cc=viro@math.psu.edu \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.