diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-16 14:58:29 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-16 14:58:29 -0400 |
commit | 714d8e7e27197dd39b2550e762a6a6fcf397a471 (patch) | |
tree | bc989a2a0e14f21912943e56d0002a26a2b7793e /arch/arm/kernel | |
parent | d19d5efd8c8840aa4f38a6dfbfe500d8cc27de46 (diff) | |
parent | 6d1966dfd6e0ad2f8aa4b664ae1a62e33abe1998 (diff) |
Merge tag 'arm64-upstream' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux
Pull arm64 updates from Will Deacon:
"Here are the core arm64 updates for 4.1.
Highlights include a significant rework to head.S (allowing us to boot
on machines with physical memory at a really high address), an AES
performance boost on Cortex-A57 and the ability to run a 32-bit
userspace with 64k pages (although this requires said userspace to be
built with a recent binutils).
The head.S rework spilt over into KVM, so there are some changes under
arch/arm/ which have been acked by Marc Zyngier (KVM co-maintainer).
In particular, the linker script changes caused us some issues in
-next, so there are a few merge commits where we had to apply fixes on
top of a stable branch.
Other changes include:
- AES performance boost for Cortex-A57
- AArch32 (compat) userspace with 64k pages
- Cortex-A53 erratum workaround for #845719
- defconfig updates (new platforms, PCI, ...)"
* tag 'arm64-upstream' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux: (39 commits)
arm64: fix midr range for Cortex-A57 erratum 832075
arm64: errata: add workaround for cortex-a53 erratum #845719
arm64: Use bool function return values of true/false not 1/0
arm64: defconfig: updates for 4.1
arm64: Extract feature parsing code from cpu_errata.c
arm64: alternative: Allow immediate branch as alternative instruction
arm64: insn: Add aarch64_insn_decode_immediate
ARM: kvm: round HYP section to page size instead of log2 upper bound
ARM: kvm: assert on HYP section boundaries not actual code size
arm64: head.S: ensure idmap_t0sz is visible
arm64: pmu: add support for interrupt-affinity property
dt: pmu: extend ARM PMU binding to allow for explicit interrupt affinity
arm64: head.S: ensure visibility of page tables
arm64: KVM: use ID map with increased VA range if required
arm64: mm: increase VA range of identity map
ARM: kvm: implement replacement for ld's LOG2CEIL()
arm64: proc: remove unused cpu_get_pgd macro
arm64: enforce x1|x2|x3 == 0 upon kernel entry as per boot protocol
arm64: remove __calc_phys_offset
arm64: merge __enable_mmu and __turn_mmu_on
...
Diffstat (limited to 'arch/arm/kernel')
-rw-r--r-- | arch/arm/kernel/vmlinux.lds.S | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/arch/arm/kernel/vmlinux.lds.S b/arch/arm/kernel/vmlinux.lds.S index 7a301be9ac67..8b60fde5ce48 100644 --- a/arch/arm/kernel/vmlinux.lds.S +++ b/arch/arm/kernel/vmlinux.lds.S | |||
@@ -11,7 +11,7 @@ | |||
11 | #ifdef CONFIG_ARM_KERNMEM_PERMS | 11 | #ifdef CONFIG_ARM_KERNMEM_PERMS |
12 | #include <asm/pgtable.h> | 12 | #include <asm/pgtable.h> |
13 | #endif | 13 | #endif |
14 | 14 | ||
15 | #define PROC_INFO \ | 15 | #define PROC_INFO \ |
16 | . = ALIGN(4); \ | 16 | . = ALIGN(4); \ |
17 | VMLINUX_SYMBOL(__proc_info_begin) = .; \ | 17 | VMLINUX_SYMBOL(__proc_info_begin) = .; \ |
@@ -23,7 +23,7 @@ | |||
23 | VMLINUX_SYMBOL(__idmap_text_start) = .; \ | 23 | VMLINUX_SYMBOL(__idmap_text_start) = .; \ |
24 | *(.idmap.text) \ | 24 | *(.idmap.text) \ |
25 | VMLINUX_SYMBOL(__idmap_text_end) = .; \ | 25 | VMLINUX_SYMBOL(__idmap_text_end) = .; \ |
26 | . = ALIGN(32); \ | 26 | . = ALIGN(PAGE_SIZE); \ |
27 | VMLINUX_SYMBOL(__hyp_idmap_text_start) = .; \ | 27 | VMLINUX_SYMBOL(__hyp_idmap_text_start) = .; \ |
28 | *(.hyp.idmap.text) \ | 28 | *(.hyp.idmap.text) \ |
29 | VMLINUX_SYMBOL(__hyp_idmap_text_end) = .; | 29 | VMLINUX_SYMBOL(__hyp_idmap_text_end) = .; |
@@ -343,8 +343,11 @@ SECTIONS | |||
343 | */ | 343 | */ |
344 | ASSERT((__proc_info_end - __proc_info_begin), "missing CPU support") | 344 | ASSERT((__proc_info_end - __proc_info_begin), "missing CPU support") |
345 | ASSERT((__arch_info_end - __arch_info_begin), "no machine record defined") | 345 | ASSERT((__arch_info_end - __arch_info_begin), "no machine record defined") |
346 | |||
346 | /* | 347 | /* |
347 | * The HYP init code can't be more than a page long. | 348 | * The HYP init code can't be more than a page long, |
349 | * and should not cross a page boundary. | ||
348 | * The above comment applies as well. | 350 | * The above comment applies as well. |
349 | */ | 351 | */ |
350 | ASSERT(((__hyp_idmap_text_end - __hyp_idmap_text_start) <= PAGE_SIZE), "HYP init code too big") | 352 | ASSERT(__hyp_idmap_text_end - (__hyp_idmap_text_start & PAGE_MASK) <= PAGE_SIZE, |
353 | "HYP init code too big or misaligned") | ||