[IA64] rework memory attribute aliasing
commit32e62c636a728cb39c0b3bd191286f2ca65d4028
authorBjorn Helgaas <bjorn.helgaas@hp.com>
Fri, 5 May 2006 23:19:50 +0000 (5 17:19 -0600)
committerTony Luck <tony.luck@intel.com>
Mon, 8 May 2006 23:32:05 +0000 (8 16:32 -0700)
tree656454a01e720819103c172daae15b5f2fd85d68
parent6810b548b25114607e0814612d84125abccc0a4f
[IA64] rework memory attribute aliasing

This closes a couple holes in our attribute aliasing avoidance scheme:

  - The current kernel fails mmaps of some /dev/mem MMIO regions because
    they don't appear in the EFI memory map.  This keeps X from working
    on the Intel Tiger box.

  - The current kernel allows UC mmap of the 0-1MB region of
    /sys/.../legacy_mem even when the chipset doesn't support UC
    access.  This causes an MCA when starting X on HP rx7620 and rx8620
    boxes in the default configuration.

There's more detail in the Documentation/ia64/aliasing.txt file this
adds, but the general idea is that if a region might be covered by
a granule-sized kernel identity mapping, any access via /dev/mem or
mmap must use the same attribute as the identity mapping.

Otherwise, we fall back to using an attribute that is supported
according to the EFI memory map, or to using UC if the EFI memory
map doesn't mention the region.

Signed-off-by: Bjorn Helgaas <bjorn.helgaas@hp.com>
Signed-off-by: Tony Luck <tony.luck@intel.com>
Documentation/ia64/aliasing.txt [new file with mode: 0644]
arch/ia64/kernel/efi.c
arch/ia64/mm/ioremap.c
arch/ia64/pci/pci.c
include/asm-ia64/io.h
include/asm-ia64/pgtable.h
include/linux/efi.h