Re: [PATCH] module: kzalloc mod->ref

From: richard kennedy
Date: Wed Jan 14 2009 - 12:51:48 EST


Kyle McMartin wrote:
> On Wed, Jan 14, 2009 at 10:09:59AM +0100, Takashi Iwai wrote:
>> At Tue, 13 Jan 2009 22:35:33 -0500,
>> Kyle McMartin wrote:
>>> From: Kyle McMartin <kyle@xxxxxxxxxx>
>>>
>>> Dynamically allocate mod->ref instead of fixing it in the struct module.
>>> Reduces on disk space wasted in the module .ko, and kills a loop
>>> initializing the local_t it contains since we can just kzalloc it.
>>>
>>> This matters when we're talking about large NR_CPUS.
>>>
>>> Signed-off-by: Kyle McMartin <kyle@xxxxxxxxxx>
>>> ---
>>> The patch removing cacheline_aligned from struct module_ref should be
>>> applied as well to cut down on the amount of memory we allocate. This
>>> patch makes a nice stopgap until we have per_cpu module references.
>>>
>>> cheers, Kyle
>> Similar patches (including mine) have been already posted, but no
>> proceed until now...
>> http://lkml.org/lkml/2008/11/11/315
>
> Ah, sigh.
>
> It would be nice to get this sorted out, since we're serious wasting
> disk space for no good reason...
>
> Although as Richard points out, dropping the cacheline_aligned might
> drop networking performance (which, sigh, is also stupid) but allocating
> 128b * NR_CPUS is just a ridiculous amount of memory to waste for a
> reference count...
>
Aside from the code in socket does this reference count really get used
that often? Atomic_t gets used for ref counts is lots of other places in
the kernel, so why not turn module_ref into an atomic counter & drop the
array entirely saving all of the memory & disk space?

I do wonder if socket could manage its module lifetimes in some other
way, then we really could just use an atomic module ref without too much
impact. I didn't get very far in trying to work out what exactly was
going on in socket.c but maybe it's worth another look.

I don't have any network test harness so it's difficult to tell what
impact any code change is going to have. Do you have any suggestions for
a good test of this?

regards
Richard


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