How the linux use BAT
benh at kernel.crashing.org
Fri Oct 28 08:37:10 EST 2005
On Thu, 2005-10-27 at 08:05 -0500, Noah yan wrote:
> I am studying source code for power mac. I am curious how linux use
> the BAT MMU.
> The address translation of BAT MMU is parallel with that of
> segment/page MMU. BAT MMU is known as superpages in other
> I am not good at the kernel coding part, hope that my questions share
> the common fundermental with you and no stupid.
> Here is my questions:
> Is the kernel turn BAT MMU on? if so, a BAT array have been setup for
> that, which part of the kernel code does this?
> If BAT MMU is used, how about segment/page address translation in
> kernel, is this also enabled and page table is setup?
> If both BAT and seg/page are enabled, how the kernel make sure that
> the correct one is used in adress translation?
Both are used and they don't overlap (well, they can overlap but if they
do, the BAT takes over).
> Is kernel really use the segment MMU of the powerpc, I have an
> impression that most kernel only use the page MMU?
page MMU vs. segment MMU ? hrm... what do you mean ? :) There is one MMU
in the "classsic" PowerPC and it does segment and hash table, you have to
use both, you can't just use one or the other :) You virtual addresses
go through the segments first to get the vsid which is then used along
with the remaining bits of the address to hash into the hash table in
order to get to the translations.
The way linux uses BATs is for the kernel linear mapping. Linux uses by
default (though that can be configued differently) a 3G/1G split, that
is the low 3G of address space are used by userland (and covered by the
user page tables) and the high 1G are used by the kernel. That kernel
space itself is split into a bottom part up to 768Mb (by default, that
can also be configured differently) which is the linear mapping, that is
a single linear mapping of all RAM from 0xc0000000. The rest of the
kernel space is mapped with page tables and known as the kernel virtual
space, used for vmalloc and ioremap.
The BATs are used for the linear mapping. They "override" the page
tables over it if any (though we usually don't bother setting up PTEs
over the space that is BAT mapped). They basically improve performances
by not requiring to go through the hash trasnslation for most kernel
accesses to memory and not using space in the TLB/ERAT.
More information about the Linuxppc-dev