From: Nicholas Mc Guire <der.herr-kA1LtwSENNE@public.gmane.org>
To: Julia Lawall <julia.lawall-L2FTfq7BK8M@public.gmane.org>
Cc: Mike Marciniszyn
<mike.marciniszyn-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>,
devel-gWbeCf7V1WCQmaza687I9mD2FQJk+8+b@public.gmane.org,
linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
dledford-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org,
linux-next-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
Cocci-/FJkirnvOdkvYVN+rsErww@public.gmane.org
Subject: Re: [Cocci] [PATCH] staging/rdma/hfi1: Fix a possible null pointer dereference
Date: Fri, 18 Dec 2015 14:20:25 +0000 [thread overview]
Message-ID: <20151218142025.GA32208@osadl.at> (raw)
In-Reply-To: <alpine.DEB.2.02.1512180727310.2052-bi+AKbBUZKagILUCTcTcHdKyNwTtLsGr@public.gmane.org>
On Fri, Dec 18, 2015 at 07:33:36AM +0100, Julia Lawall wrote:
>
>
> On Mon, 14 Dec 2015, Nicholas Mc Guire wrote:
>
> > On Thu, Dec 10, 2015 at 11:13:38AM -0500, Mike Marciniszyn wrote:
> > > From: Easwar Hariharan <easwar.hariharan-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
> > >
> > > A code inspection pointed out that kmalloc_array may return NULL and
> > > memset doesn't check the input pointer for NULL, resulting in a possible
> > > NULL dereference. This patch fixes this.
> > >
> > > Reviewed-by: Mike Marciniszyn <mike.marciniszyn-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
> > > Signed-off-by: Easwar Hariharan <easwar.hariharan-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
> > > ---
> > > drivers/staging/rdma/hfi1/chip.c | 2 ++
> > > 1 file changed, 2 insertions(+)
> > >
> > > diff --git a/drivers/staging/rdma/hfi1/chip.c b/drivers/staging/rdma/hfi1/chip.c
> > > index dc69159..49d49b2 100644
> > > --- a/drivers/staging/rdma/hfi1/chip.c
> > > +++ b/drivers/staging/rdma/hfi1/chip.c
> > > @@ -10129,6 +10129,8 @@ static void init_qos(struct hfi1_devdata *dd, u32 first_ctxt)
> > > if (num_vls * qpns_per_vl > dd->chip_rcv_contexts)
> > > goto bail;
> > > rsmmap = kmalloc_array(NUM_MAP_REGS, sizeof(u64), GFP_KERNEL);
> > > + if (!rsmmap)
> > > + goto bail;
> > > memset(rsmmap, rxcontext, NUM_MAP_REGS * sizeof(u64));
> > > /* init the local copy of the table */
> > > for (i = 0, ctxt = first_ctxt; i < num_vls; i++) {
> > >
> > > --
> >
> > Based on this report a generalization of unchecked use turned up one more
> > case in the current kernel (patch sent). Probably the when block needs
> > some cleanup, but findings like this definitely are a case for coccinelle
> > scanners.
> >
> > <snip>
> > /// check for missing NULL check before use
> > //
> > // missing check in:
> > // ./drivers/staging/rdma/hfi1/chip.c:10131 unchecked allocation
> > // in -next-20151214
> > // reported-by Mike Marciniszyn <mike.marciniszyn-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
> > //
> > // after generalization this also found:
> > // ./drivers/clk/shmobile/clk-div6.c:197 unchecked allocation
> >
> > virtual context
> > virtual org
> > virtual report
> >
> > @badmemset@
> > expression mem;
> > position p;
> > statement S;
> > @@
> >
> > <+...
> > *mem = kmalloc_array@p(...);
> > ... when != if (!mem || ...) S
> > when != if (... && !mem) S
> > when != if (mem == NULL || ...) S
> > when != if (... && mem == NULL) S
> > when != if (unlikely(mem == NULL)) S
> > when != if (unlikely(!mem)) S
> > when != if (likely(!mem)) S
> > when != if (likely(mem == NULL)) S
> > return;
> > ...+>
> >
> > @script:python@
> > p << badmemset.p;
> > @@
> >
> > print "%s:%s unchecked allocation" % (p[0].file,p[0].line)
> >
> > <snip>
>
> How about the following? I got two hits with this, in
> drivers/clk/shmobile/clk-div6.c and drivers/staging/rdma/hfi1/chip.c.
>
> @@
> expression mem;
> identifier f;
> @@
>
> *mem = kmalloc_array(...);
> ... when != mem == NULL
> when != mem != NULL
> (
works perfectly for this case - thanks
I actually initially used the "template" from api/alloc/kzalloc-simple.cocci
but that did not catch all cases for the kmalloc_array scanner.
Poping your proposal into kzalloc-simple.cocci seems to be finding quite
a few additional cases will review them to see if there are any false
positives - but a first scan did show that most of the reported cases
seem to be valid.
thx!
hofrat
--
To unsubscribe from this list: send the line "unsubscribe linux-rdma" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2015-12-18 14:20 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-12-10 16:13 [PATCH] staging/rdma/hfi1: Fix a possible null pointer dereference Mike Marciniszyn
2015-12-14 13:28 ` Nicholas Mc Guire
2015-12-18 6:33 ` [Cocci] " Julia Lawall
[not found] ` <alpine.DEB.2.02.1512180727310.2052-bi+AKbBUZKagILUCTcTcHdKyNwTtLsGr@public.gmane.org>
2015-12-18 14:20 ` Nicholas Mc Guire [this message]
2015-12-20 12:59 ` Julia Lawall
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=20151218142025.GA32208@osadl.at \
--to=der.herr-ka1ltwsenne@public.gmane.org \
--cc=Cocci-/FJkirnvOdkvYVN+rsErww@public.gmane.org \
--cc=devel-gWbeCf7V1WCQmaza687I9mD2FQJk+8+b@public.gmane.org \
--cc=dledford-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
--cc=julia.lawall-L2FTfq7BK8M@public.gmane.org \
--cc=linux-next-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=mike.marciniszyn-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).