[RFC PATCH 00/18] ARM: Add support for the Large Physical Address Extensions

Catalin Marinas catalin.marinas at arm.com
Mon Oct 25 04:59:33 EDT 2010


Hi,

This set of patches adds support for the Large Physical Extensions on
the ARM architecture (available with the Cortex-A15 processor). LPAE
comes with a 3-level page table format (compared to 2-level for the
classic one), allowing up to 40-bit physical address space.

These patches split the arch/arm/ page table definitions into
corresponding 2-level and 3-level files and ensure that the common code
works with both variants.  They also fix assumptions regarding the size
of the physical address.  The outer cache support is currently
restricted to 32-bit physical addresses.

The LPAE page table format uses the simplified permission model (as
described in the ARM ARM) and domains are no longer available (requiring
an additional patch which is already in RMK's patch system).

The ARM LPAE documentation is available from (free registration needed):

http://infocenter.arm.com/help/topic/com.arm.doc.ddi0406b_virtualization_extns/index.html

The full set of patches (kernel fixes, LPAE and support for an emulated
Versatile Express with Cortex-A15 tile) is available on this branch:

git://git.kernel.org/pub/scm/linux/kernel/git/cmarinas/linux-2.6-cm.git arm-lpae

Any comments are welcome. Thanks.


Catalin Marinas (11):
      ARM: LPAE: Use PMD_(SHIFT|SIZE|MASK) instead of PGDIR_*
      ARM: LPAE: Factor out 2-level page table definitions into separate files
      ARM: LPAE: Do not assume Linux PTEs are always at PTRS_PER_PTE offset
      ARM: LPAE: Introduce L_PTE_NOEXEC and L_PTE_NOWRITE
      ARM: LPAE: Introduce the 3-level page table format definitions
      ARM: LPAE: Page table maintenance for the 3-level format
      ARM: LPAE: MMU setup for the 3-level page table format
      ARM: LPAE: Add fault handling support
      ARM: LPAE: Add context switching support
      ARM: LPAE: Add SMP support for the 3-level page table format
      ARM: LPAE: Add the Kconfig entries

Will Deacon (7):
      ARM: LPAE: use u32 instead of unsigned long for 32-bit ptes
      ARM: LPAE: use phys_addr_t instead of unsigned long for physical addresses
      ARM: LPAE: ensure dma_addr_t is the same size as phys_addr_t
      ARM: LPAE: mark memory banks with start > ULONG_MAX as highmem
      ARM: LPAE: use phys_addr_t for physical start address in early_mem
      ARM: LPAE: add support for ATAG_MEM64
      ARM: LPAE: define printk format for physical addresses and page table entries


 arch/arm/include/asm/cpu-multi32.h          |    8 +
 arch/arm/include/asm/cpu-single.h           |    4 
 arch/arm/include/asm/memory.h               |   17 +-
 arch/arm/include/asm/outercache.h           |   14 +
 arch/arm/include/asm/page-nommu.h           |    8 -
 arch/arm/include/asm/page.h                 |   42 ----
 arch/arm/include/asm/pgalloc.h              |   34 +++
 arch/arm/include/asm/pgtable-2level-hwdef.h |   91 +++++++++
 arch/arm/include/asm/pgtable-2level-types.h |   64 ++++++
 arch/arm/include/asm/pgtable-2level.h       |  150 +++++++++++++++
 arch/arm/include/asm/pgtable-3level-hwdef.h |   78 ++++++++
 arch/arm/include/asm/pgtable-3level-types.h |   55 ++++++
 arch/arm/include/asm/pgtable-3level.h       |  113 +++++++++++
 arch/arm/include/asm/pgtable-hwdef.h        |   81 +-------
 arch/arm/include/asm/pgtable.h              |  267 +++++++++++----------------
 arch/arm/include/asm/proc-fns.h             |   13 +
 arch/arm/include/asm/setup.h                |   12 +
 arch/arm/include/asm/types.h                |   25 +--
 arch/arm/kernel/compat.c                    |    4 
 arch/arm/kernel/head.S                      |   87 +++++++--
 arch/arm/kernel/module.c                    |    2 
 arch/arm/kernel/setup.c                     |   19 ++
 arch/arm/kernel/smp.c                       |   36 +++-
 arch/arm/mm/Kconfig                         |   10 +
 arch/arm/mm/alignment.c                     |    8 +
 arch/arm/mm/context.c                       |   18 ++
 arch/arm/mm/dma-mapping.c                   |    6 -
 arch/arm/mm/fault.c                         |   88 ++++++++-
 arch/arm/mm/init.c                          |    9 +
 arch/arm/mm/ioremap.c                       |    8 +
 arch/arm/mm/mm.h                            |    8 -
 arch/arm/mm/mmu.c                           |   94 ++++++----
 arch/arm/mm/pgd.c                           |   18 +-
 arch/arm/mm/proc-macros.S                   |    5 -
 arch/arm/mm/proc-v7.S                       |  102 ++++++++++
 35 files changed, 1193 insertions(+), 405 deletions(-)
 create mode 100644 arch/arm/include/asm/pgtable-2level-hwdef.h
 create mode 100644 arch/arm/include/asm/pgtable-2level-types.h
 create mode 100644 arch/arm/include/asm/pgtable-2level.h
 create mode 100644 arch/arm/include/asm/pgtable-3level-hwdef.h
 create mode 100644 arch/arm/include/asm/pgtable-3level-types.h
 create mode 100644 arch/arm/include/asm/pgtable-3level.h

-- 
Catalin



More information about the linux-arm-kernel mailing list