lib/idr.c: initialize struct idr_layer

!MAILaRCHIVE_VOTE_RePLACE
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
To: Jim Houston <jim.houston@...>
Cc: Ingo Molnar <mingo@...>, Tejun Heo <htejun@...>, Linux Kernel Mailing List <linux-kernel@...>
Date: Sunday, January 27, 2008 - 4:07 pm

Hi,

I am testing my kmemcheck patches, and it has come up with a couple of
uses of uninitialized memory in lib/idr.c. These are (the line numbers
may differ slightly):

line 135 (sub_alloc): bm = ~p->bitmap;
p->bitmap is uninitialized

line 171 (sub_alloc): if (!p->ary[m]) {
p->ary is uninitialized

line 249 (idr_get_new_above_int): pa[0]->count++;
pa[0]->count is uninitialized

I cannot guarantee that these are truly errors, but I would be
grateful if you could help me confirm/deny the validity of the
reports. Personally, I can get rid of the errors using this patch:

diff --git a/lib/idr.c b/lib/idr.c
index afbb0b1..dd28ee5 100644
--- a/lib/idr.c
+++ b/lib/idr.c
@@ -39,12 +39,16 @@ static struct idr_layer *alloc_layer(struct idr *idp)
 {
        struct idr_layer *p;
        unsigned long flags;
+       int i;

        spin_lock_irqsave(&idp->lock, flags);
        if ((p = idp->id_free)) {
                idp->id_free = p->ary[0];
                idp->id_free_cnt--;
-               p->ary[0] = NULL;
+               p->bitmap = 0;
+               for(i = 0; i < ARRAY_SIZE(p->ary); ++i)
+                       p->ary[i] = NULL;
+               p->count = 0;
        }
        spin_unlock_irqrestore(&idp->lock, flags);
        return(p);


Thanks a lot.

Vegard
--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
lib/idr.c: initialize struct idr_layer, Vegard Nossum, (Sun Jan 27, 4:07 pm)
Re: lib/idr.c: initialize struct idr_layer, Pekka Enberg, (Sun Jan 27, 5:00 pm)
Re: lib/idr.c: initialize struct idr_layer, Vegard Nossum, (Sun Jan 27, 5:17 pm)
Re: lib/idr.c: initialize struct idr_layer, Pekka J Enberg, (Sun Jan 27, 5:21 pm)
Re: lib/idr.c: initialize struct idr_layer, Vegard Nossum, (Sun Jan 27, 5:30 pm)
Re: lib/idr.c: initialize struct idr_layer, Pekka Enberg, (Sun Jan 27, 5:35 pm)
Re: lib/idr.c: initialize struct idr_layer, Vegard Nossum, (Sun Jan 27, 5:56 pm)