x86_64: CPA, fix cache attribute inconsistency bug, v2.6.22 backport
commit55f2876a0023596d6b27e20b0c806654b38ccfae
authorIngo Molnar <mingo@elte.hu>
Fri, 15 Feb 2008 19:58:22 +0000 (15 20:58 +0100)
committerOliver Pinter <oliver.pntr@gmail.com>
Tue, 4 Mar 2008 17:09:29 +0000 (4 18:09 +0100)
treec3bdbf7456fff0674203a06e3f96b59a443cd025
parent37579d1574f6c18f1f648201c6b0850ac94094cd
x86_64: CPA, fix cache attribute inconsistency bug, v2.6.22 backport

fix CPA cache attribute bug in v2.6.2[234]. When phys_base is nonzero
(when CONFIG_RELOCATABLE=y) then change_page_attr_addr() miscalculates
the secondary alias address by -14 MB (depending on the configured
offset).

The default 64-bit kernels of Fedora and Ubuntu are affected:

   $ grep RELOCA /boot/config-2.6.23.9-85.fc8
     CONFIG_RELOCATABLE=y

   $ grep RELOC /boot/config-2.6.22-14-generic
     CONFIG_RELOCATABLE=y

and probably on many other distros as well.

the bug affects all pages in the first 40 MB of physical RAM that
are allocated by some subsystem that does ioremap_nocache() on them:

       if (__pa(address) < KERNEL_TEXT_SIZE) {

Hence we might leave page table entries with inconsistent cache
attributes around (pages mapped at both UnCacheable and Write-Back),
and we can also set the wrong kernel text pages to UnCacheable.

the effects of this bug can be random slowdowns and other misbehavior.
If for example AGP allocates its aperture pages into the first 40 MB
of physical RAM, then the -14 MB bug might mark random kernel texto
pages as uncacheable, slowing down a random portion of the 64-bit
kernel until the AGP driver is unloaded.

Signed-off-by: Ingo Molnar <mingo@elte.hu>
Acked-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Oliver Pinter <oliver.pntr@gmail.com>
arch/x86_64/mm/pageattr.c