diff options
| author | Ard Biesheuvel <ard.biesheuvel@linaro.org> | 2015-03-19 16:42:26 +0000 | 
|---|---|---|
| committer | Will Deacon <will.deacon@arm.com> | 2015-03-19 19:21:56 +0000 | 
| commit | 06f75a1f6200042aa36ad40afb44dd72107b25d6 (patch) | |
| tree | 84f134705f009d74aba8637f25da3f887ea40c08 /lib/mpi/mpiutil.c | |
| parent | 06e5801b8cb3fc057d88cb4dc03c0b64b2744cda (diff) | |
ARM, arm64: kvm: get rid of the bounce page
The HYP init bounce page is a runtime construct that ensures that the
HYP init code does not cross a page boundary. However, this is something
we can do perfectly well at build time, by aligning the code appropriately.
For arm64, we just align to 4 KB, and enforce that the code size is less
than 4 KB, regardless of the chosen page size.
For ARM, the whole code is less than 256 bytes, so we tweak the linker
script to align at a power of 2 upper bound of the code size
Note that this also fixes a benign off-by-one error in the original bounce
page code, where a bounce page would be allocated unnecessarily if the code
was exactly 1 page in size.
On ARM, it also fixes an issue with very large kernels reported by Arnd
Bergmann, where stub sections with linker emitted veneers could erroneously
trigger the size/alignment ASSERT() in the linker script.
Tested-by: Marc Zyngier <marc.zyngier@arm.com>
Reviewed-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
Diffstat (limited to 'lib/mpi/mpiutil.c')
0 files changed, 0 insertions, 0 deletions
