hw/arm/virt: Support larger highmem MMIO regions
authorMatthew R. Ochs <mochs@nvidia.com>
Fri, 21 Feb 2025 14:54:19 +0000 (06:54 -0800)
committerPeter Maydell <peter.maydell@linaro.org>
Mon, 24 Feb 2025 15:03:42 +0000 (15:03 +0000)
commitf10104aeae3a17f181d5bb37b7fd7dad7fe86cba
treee931c0d56cd1335b3879af70ecebca9818f70afd
parentab544de12787035edb7ad4994a80f9cd6a6b55d7
hw/arm/virt: Support larger highmem MMIO regions

The MMIO region size required to support virtualized environments with
large PCI BAR regions can exceed the hardcoded limit configured in QEMU.
For example, a VM with multiple NVIDIA Grace-Hopper GPUs passed through
requires more MMIO memory than the amount provided by VIRT_HIGH_PCIE_MMIO
(currently 512GB). Instead of updating VIRT_HIGH_PCIE_MMIO, introduce a
new parameter, highmem-mmio-size, that specifies the MMIO size required
to support the VM configuration.

Example usage with 1TB MMIO region size:
-machine virt,gic-version=3,highmem-mmio-size=1T

Signed-off-by: Matthew R. Ochs <mochs@nvidia.com>
Reviewed-by: Gavin Shan <gshan@redhat.com>
Reviewed-by: Shameer Kolothum <shameerali.kolothum.thodi@huawei.com>
Reviewed-by: Eric Auger <eric.auger@redhat.com>
Reviewed-by: Nicolin Chen <nicolinc@nvidia.com>
Message-id: 20250221145419.1281890-1-mochs@nvidia.com
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
docs/system/arm/virt.rst
hw/arm/virt.c