Message ID | 20220616134828.129006-1-alexandru.elisei@arm.com (mailing list archive) |
---|---|
Headers | show |
Series | arm64: Allow the user to set RAM base address | expand |
On 16/06/2022 14:48, Alexandru Elisei wrote: > The series can be found at [1]. It is loosely based on the patches that > allow the user to define the VM memory layout (RAM + MMIO) [2]. I've > cherry-picked a handful of patches from that series, the rest I wrote from > scratch since there have been several changes to the way guest memory is > handled. I've chosen to focus on specifying the RAM layout with only one > RAM bank and leave the rest for a later series because this was relatively > easy to accomplish, while still being very useful. > > What this series does: for arm64, the user can now specify the base address > for RAM: > > $ ./lkvm run -m1G@2G .. # Equivalent to ./lkvm run -m1024 > > The memory units are B (bytes), K (kilobytes), M (megabytes), G > (gigabytes), T (terrabytes), P (petabytes). Lowercase is also valid. > > Want to put RAM at the top of the physical address range? Easy: > > $ ./lkvm run -m2G@1022G .. # Assumes the maximum is 40 bits of IPA > > There one limitation on the RAM base address: it must not overlap with the > MMIO range that kvmtool uses for arm/arm64, which lives below 2GB. > > Why this is useful, in my opinion: > > 1. Testing how a payload handles different memory layouts without the need > to hack kvmtool or find the hardware that implements the desired layout. > > 2. It can serve as a development tool for adding support for larger PA > ranges for Linux and KVM (currently capped at 48 bits for 4k/16k pages), or > other payloads. > > Summary of the series > ====================== > > * The series starts with refactoring how kvm->cfg.ram_size is validated > and used, followed by several cleanups in the arm and arm64 code. > > * Then patch #8 ("builtin_run: Allow standard size specifiers for memory") > introduced the ability to specify the measurement unit for memory. I > believe that typing the equivalent of 2TB in megabytes isn't appealing > for anyone. > > * More cleanups in the arm/arm64 code follow, which are needed for patch > #12 ("arm64: Allow the user to specify the RAM base address"). This is > where the ability to specify the RAM base address is introduced. > > Testing > ======= > > Same testing as before: > > - Build tested each patch for all architectures. > > - Ran an x86 kernel with and without setting the amount of RAM using the > memory specifiers; tested that setting the RAM address results in an > error. > > - Ran an arm64 kernel without setting the size, with setting the size and > with setting the size and address; tried different addresses (2G, 3G, > 256G); also tested that going below 2G or above the maximum IPA correctly > results in an error. > > - Ran all arm64 kvm-unit-test tests with similar combinations of memory > size and address (instead of 256G I used 128G, as that's where I/O lives > for qemu and kvm-unit-tests maps that unconditionally as I/O). > > - Ran all 32bit arm tests on an arm64 host with various combinations of > memory size and address (base address at 2G and 2.5G only due to a > limitation in the way the tests are set up). I have tested this series on arm64 Fast model, with memory placed from 32bit to 48bit IPA and it works well. For the series: Reviewed-and-Tested-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Hi Suzuki, Will, On Tue, Jun 21, 2022 at 06:03:22PM +0100, Suzuki K Poulose wrote: > On 16/06/2022 14:48, Alexandru Elisei wrote: > > The series can be found at [1]. It is loosely based on the patches that > > allow the user to define the VM memory layout (RAM + MMIO) [2]. I've > > cherry-picked a handful of patches from that series, the rest I wrote from > > scratch since there have been several changes to the way guest memory is > > handled. I've chosen to focus on specifying the RAM layout with only one > > RAM bank and leave the rest for a later series because this was relatively > > easy to accomplish, while still being very useful. > > > > What this series does: for arm64, the user can now specify the base address > > for RAM: > > > > $ ./lkvm run -m1G@2G .. # Equivalent to ./lkvm run -m1024 > > > > The memory units are B (bytes), K (kilobytes), M (megabytes), G > > (gigabytes), T (terrabytes), P (petabytes). Lowercase is also valid. > > > > Want to put RAM at the top of the physical address range? Easy: > > > > $ ./lkvm run -m2G@1022G .. # Assumes the maximum is 40 bits of IPA > > > > There one limitation on the RAM base address: it must not overlap with the > > MMIO range that kvmtool uses for arm/arm64, which lives below 2GB. > > > > Why this is useful, in my opinion: > > > > 1. Testing how a payload handles different memory layouts without the need > > to hack kvmtool or find the hardware that implements the desired layout. > > > > 2. It can serve as a development tool for adding support for larger PA > > ranges for Linux and KVM (currently capped at 48 bits for 4k/16k pages), or > > other payloads. > > > > Summary of the series > > ====================== > > > > * The series starts with refactoring how kvm->cfg.ram_size is validated > > and used, followed by several cleanups in the arm and arm64 code. > > > > * Then patch #8 ("builtin_run: Allow standard size specifiers for memory") > > introduced the ability to specify the measurement unit for memory. I > > believe that typing the equivalent of 2TB in megabytes isn't appealing > > for anyone. > > > > * More cleanups in the arm/arm64 code follow, which are needed for patch > > #12 ("arm64: Allow the user to specify the RAM base address"). This is > > where the ability to specify the RAM base address is introduced. > > > > Testing > > ======= > > > > Same testing as before: > > > > - Build tested each patch for all architectures. > > > > - Ran an x86 kernel with and without setting the amount of RAM using the > > memory specifiers; tested that setting the RAM address results in an > > error. > > > > - Ran an arm64 kernel without setting the size, with setting the size and > > with setting the size and address; tried different addresses (2G, 3G, > > 256G); also tested that going below 2G or above the maximum IPA correctly > > results in an error. > > > > - Ran all arm64 kvm-unit-test tests with similar combinations of memory > > size and address (instead of 256G I used 128G, as that's where I/O lives > > for qemu and kvm-unit-tests maps that unconditionally as I/O). > > > > - Ran all 32bit arm tests on an arm64 host with various combinations of > > memory size and address (base address at 2G and 2.5G only due to a > > limitation in the way the tests are set up). > > I have tested this series on arm64 Fast model, with memory placed from > 32bit to 48bit IPA and it works well. > > For the series: > > Reviewed-and-Tested-by: Suzuki K Poulose <suzuki.poulose@arm.com> Thank you for the review and testing! Will, do you want me to respin the series to gather all the Reviewed-by and Tested-by tags? Thanks, Alex
On Thu, 16 Jun 2022 14:48:16 +0100, Alexandru Elisei wrote: > The series can be found at [1]. It is loosely based on the patches that > allow the user to define the VM memory layout (RAM + MMIO) [2]. I've > cherry-picked a handful of patches from that series, the rest I wrote from > scratch since there have been several changes to the way guest memory is > handled. I've chosen to focus on specifying the RAM layout with only one > RAM bank and leave the rest for a later series because this was relatively > easy to accomplish, while still being very useful. > > [...] Applied to kvmtool (master), thanks! [01/12] Use MB for megabytes consistently https://git.kernel.org/will/kvmtool/c/024c331b8483 [02/12] builtin-run: Always use RAM size in bytes https://git.kernel.org/will/kvmtool/c/9d655190e466 [03/12] builtin-run: Rework RAM size validation https://git.kernel.org/will/kvmtool/c/28b96259fbdf [04/12] builtin-run: Add arch hook to validate VM configuration https://git.kernel.org/will/kvmtool/c/abe3f28a9c07 [05/12] arm/arm64: Fail if RAM size is too large for 32-bit guests https://git.kernel.org/will/kvmtool/c/cce5a4f6ae9b [06/12] arm/arm64: Kill the ARM_MAX_MEMORY() macro https://git.kernel.org/will/kvmtool/c/1af57dcdce51 [07/12] arm/arm64: Kill the ARM_HIMAP_MAX_MEMORY() macro https://git.kernel.org/will/kvmtool/c/d6d4220133b7 [08/12] builtin_run: Allow standard size specifiers for memory https://git.kernel.org/will/kvmtool/c/a9c24ec78b4f [09/12] kvm__arch_init: Remove hugetlbfs_path and ram_size as parameters https://git.kernel.org/will/kvmtool/c/5e9c654e60e8 [10/12] arm/arm64: Consolidate RAM initialization in kvm__init_ram() https://git.kernel.org/will/kvmtool/c/a37dad0ea9c7 [11/12] Introduce kvm__arch_default_ram_address() https://git.kernel.org/will/kvmtool/c/3f7e48f621bb [12/12] arm64: Allow the user to specify the RAM base address https://git.kernel.org/will/kvmtool/c/8b91a1828ee9 Cheers,