On 5/7/07, Bert Wesarg <[EMAIL PROTECTED]> wrote:
[EMAIL PROTECTED] wrote:
> +     if (ctor || dtor) {
> +             so = kzalloc(sizeof(struct slab_ops), GFP_KERNEL);
> +             so->ctor = ctor;
> +             so->dtor = dtor;
> +     }
> +     return  __kmem_cache_create(s, size, align, flags, so);
Is this a memory leak?

Yes, but see:

On 5/5/07, [EMAIL PROTECTED] <[EMAIL PROTECTED]> wrote:
If constructor or destructor are specified then we will allocate a slab_ops
structure and populate it with the values specified. Note that this will
cause a memory leak if the slab is disposed of later. If you need disposable
slabs then the new API must be used.

BTW:

> +     if (ctor || dtor) {
> +             so = kzalloc(sizeof(struct slab_ops), GFP_KERNEL);
> +             so->ctor = ctor;

It's also a potential oops, actually. kzalloc's return must be checked.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to