[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <m1vep4ecd8.fsf@ebiederm.dsl.xmission.com>
Date: Mon, 07 Aug 2006 10:31:31 -0600
From: ebiederm@...ssion.com (Eric W. Biederman)
To: Andi Kleen <ak@...e.de>
Cc: Andrew Morton <akpm@...l.org>,
"Protasevich, Natalie" <Natalie.Protasevich@...sys.com>,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH] x86_64: Double the per cpu area size
Andi Kleen <ak@...e.de> writes:
>>
>> #include <asm/pda.h>
>>
>> +#define PERCPU_ENOUGH_ROOM 65536
>
> I would prefer if you didn't do that unconditionally. Can you make
> it dependent on NR_IRQS or so? Can you add a test for CONFIG_TINY
> to make it smaller?
We already ignore this variable for the per cpu allocation if we
build a kernel wihtout module support. I guess a good fix could
entail changing the concept to be how much per cpu room to reserve
for modules.
I'm a big believer in stupid and simple solutions for as long as
you can get away with it. When people trip over this then
it will be clear what the real problem is and we can fix it.
> Also longer term it should really properly fixed
Agreed. But we need a solution that works now so we have a solution
for when the 2.6.19 window opens up. There is no agreement on even
what a proper fix is, or even what it looks like. Keeping the data
per cpu seems about as good as anything else for memory size savings,
as most systems don't have many cpus.
Throwing a few more bytes at the problem solves it today and for
all systems currently built. This buys us time to look at and discuss
the problem. With MSI starting to be useful I have no expectation
that we will stop here.
There are two fundamental problems that need to be fixed.
- Small size and static allocate of the per cpu area.
- Data structures that don't scale to large numbers of possible irqs.
Solving either of these two fundamental problems involves reexamining
some of our current trade offs in the kernel.
The proper fix for irqs is a refactoring of the data structures so
we can handle a 16 or better yet a 24 bit irq number, and only
allocate the pieces we need. A proper fix needs to find someway
not to keep a counter for every cpu and irq pair, which no one has
the will to seriously consider right now.
The proper fix for the per cpu area size is much trickier.
Especially if we every reach the point of hotplug NUMA nodes.
One odd observation is that the amount of per cpu data we want
grows with the size of the system.
Eric
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists