Re: [Patch] statistics infrastructure - update 10

From: Andrew Morton
Date: Thu Jul 13 2006 - 03:58:27 EST


On Wed, 12 Jul 2006 18:45:08 +0200
Martin Peschke <mp3@xxxxxxxxxx> wrote:

> On Wed, 2006-07-12 at 09:10 -0700, Andrew Morton wrote:
> > On Wed, 12 Jul 2006 14:27:39 +0200
> > Martin Peschke <mp3@xxxxxxxxxx> wrote:
> >
> > > +#define statistic_ptr(stat, cpu) \
> > > + ((struct percpu_data*)((stat)->data))->ptrs[(cpu)]
> >
> > This would be the only part of the kernel which uses percpu_data directly -
> > everything else uses the APIs (ie: per_cpu_ptr()). How come?
>
> The API, i.e. per_cpu_ptr(), doesn't allow to assign a value to any of
> the pointers in struct percpu_data. I need that capability because I
> make use of cpu hotplug notifications to fix per-cpu data at run time.

Fair enough, I guess.

> With regard to memory footprint this is much more efficient than using
> alloc_percpu().

How much storage are we talking about here? I find it a bit hard to work
that out.

> Is it be preferable to add something like set_per_cpu_ptr() to the API?

hm. Add a generic extension to a generic interface within a specific
subsystem versus doing it generically. Hard call ;)


I'd suggest that you:

- Create a new __alloc_percpu_mask(size_t size, cpumask_t cpus)

- Make that function use your newly added

percpu_data_populate(struct percpu_data *p, int cpu, size_t size, gfp_t gfp);

(maybe put `size' into 'struct percpu_data'?)

- implement __alloc_percpu() as __alloc_percpu_mask(size, cpu_possible_map)

- hack around madly until it compiles on uniprocessor.
-
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/