[PATCHv2 00/15] arm64: 16K translation granule support
Suzuki K. Poulose
suzuki.poulose at arm.com
Tue Sep 15 08:41:09 PDT 2015
From: "Suzuki K. Poulose" <suzuki.poulose at arm.com>
This series enables the 16K page size support on Linux for arm64.
Adds support for 48bit VA(4 level), 47bit VA(3 level) and
36bit VA(2 level) with 16K. 16K was a late addition to the architecture
and is not implemented by all CPUs. Added a check to ensure the
selected granule size is supported by the CPU, failing which the CPU
won't proceed with booting. Also the kernel page size is added to the
kernel image header (patch from Ard).
KVM bits have been tested on a fast model with GICv3 using kvmtool [1].
Patches 1-7 cleans up the kernel page size handling code.
Patch 8 Adds a check to ensure the CPU supports the selected granule size.
Patch 9 Adds the page size information to image header.
Patches 10-13 Fixes some issues with the KVM bits, mainly the fake PGD
handling code.
Patches 14-15 Adds the 16k page size support bits.
This series applies on top of 4.3-rc1.
The tree is also available here:
git://linux-arm.org/linux-skp.git 16k/v2-4.3-rc1
Changes since V1:
- Rebase to 4.3-rc1
- Fix vmemmap_populate for 16K (use !ARM64_SWAPPER_USES_SECTION_MAPS)
- Better description for patch2 (suggested-by: Ard)
- Add page size information to the image header flags.
- Added reviewed-by/tested-by Ard.
[1] git://git.kernel.org/pub/scm/linux/kernel/git/will/kvmtool.git
Ard Biesheuvel (1):
arm64: Add page size to the kernel image header
Suzuki K. Poulose (14):
arm64: Move swapper pagetable definitions
arm64: Handle section maps for swapper/idmap
arm64: Introduce helpers for page table levels
arm64: Calculate size for idmap_pg_dir at compile time
arm64: Handle 4 level page table for swapper
arm64: Clean config usages for page size
arm64: Kconfig: Fix help text about AArch32 support with 64K pages
arm64: Check for selected granule support
arm64: kvm: Fix {V}TCR_EL2_TG0 mask
arm64: Cleanup VTCR_EL2 computation
arm: kvm: Move fake PGD handling to arch specific files
arm64: kvm: Rewrite fake pgd handling
arm64: Add 16K page size support
arm64: 36 bit VA
Documentation/arm64/booting.txt | 7 +-
arch/arm/include/asm/kvm_mmu.h | 7 ++
arch/arm/kvm/mmu.c | 44 ++--------
arch/arm64/Kconfig | 37 +++++++--
arch/arm64/Kconfig.debug | 2 +-
arch/arm64/include/asm/boot.h | 1 +
arch/arm64/include/asm/fixmap.h | 4 +-
arch/arm64/include/asm/kernel-pgtable.h | 77 ++++++++++++++++++
arch/arm64/include/asm/kvm_arm.h | 29 +++++--
arch/arm64/include/asm/kvm_mmu.h | 135 +++++++++++++++++++++----------
arch/arm64/include/asm/page.h | 20 +----
arch/arm64/include/asm/pgtable-hwdef.h | 15 +++-
arch/arm64/include/asm/sysreg.h | 8 ++
arch/arm64/include/asm/thread_info.h | 4 +-
arch/arm64/kernel/head.S | 71 +++++++++-------
arch/arm64/kernel/image.h | 5 +-
arch/arm64/kernel/vmlinux.lds.S | 1 +
arch/arm64/mm/mmu.c | 72 ++++++++---------
arch/arm64/mm/proc.S | 4 +-
19 files changed, 348 insertions(+), 195 deletions(-)
create mode 100644 arch/arm64/include/asm/kernel-pgtable.h
--
1.7.9.5
More information about the linux-arm-kernel
mailing list