Re: duplicate entry check in kmem_cache_create

Steve French (smfrench@austin.rr.com)
Wed, 18 Jun 2003 19:08:18 -0500


Just trying to be paranoid safe in module init code. You can't unload a
module with live objects
easily but in at least the case of force unloading of modules (in this
case the cifs filesystem) is
apparently permitted by the kernel if you specify force and unless there
is a way to autounmount
when someone forces you into your module exit routine (i.e. on rmmod
<filesystemname.o> -f)
before all associated mounts are unmounted, I was thinking about whether
the filesystem's module
init code should check if the filesystem module unloaded (from a slab
perspective) cleanly but
couldn't think of an easy way to check unless I intentionally leave some
/proc/fs/ entry around
when module unloading fails (and use the /proc/fs/cifs entry as a hint
that module unloading was
not clean so don't even think about trying to do a module init on this
filesystem).

Andrew Morton wrote:

>Steve French <smfrench@austin.rr.com> wrote:
>
>
>>Is there a recommended way to check to see if a slab cache with
>>a specific name exists before calling kmem_cache_create?
>>
>>I was able to force it into the BUG() at about line 1160 of slab.c by
>>removing my
>>module (rmmod -f) while some of my slab cache objects (e.g. private inode
>>info) were still in use, and then reloading my module which called
>>kmem_cache_create with a name that already existed.
>>
>>
>
>errr, why on earth was the filesystem unloadable when it still had live
>objects floating about?
>
>At the very least, if the slab code tries to call a destructor it will ruin
>your whole day.
>
>
>
>
>

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/