> On 11. Mar 2026, at 12:35, Magnus Kulke <[email protected]>
> wrote:
>
> This change disable la57 paging on the mshv hypervisor on both the
> mshv processor feature bitmap and mask the cpuid feature leaf to the
> guest.
>
> Since the removal of hypervisor-assisted gva=>gpa translation in
> 1c85a4a3d7 we have seen MMIO errors in guests on la57-enabled hw. We
> will have to investigate and test this further.
Hello,
This should already be fixed on master since yesterday. Can you repro this?
Thank you,
-Mohamed
>
> Signed-off-by: Magnus Kulke <[email protected]>
> ---
> accel/mshv/mshv-all.c | 7 +++++++
> target/i386/mshv/mshv-cpu.c | 6 ++++++
> 2 files changed, 13 insertions(+)
>
> diff --git a/accel/mshv/mshv-all.c b/accel/mshv/mshv-all.c
> index eab967ff07..ea3aacf6e0 100644
> --- a/accel/mshv/mshv-all.c
> +++ b/accel/mshv/mshv-all.c
> @@ -142,6 +142,8 @@ static int create_partition(int mshv_fd, int *vm_fd)
> int ret;
> uint64_t pt_flags, host_proc_features;
> union hv_partition_processor_xsave_features disabled_xsave_features;
> + union hv_partition_processor_features disabled_proc_features = {0};
> +
> struct mshv_create_partition_v2 args = {0};
> uint32_t feature_banks[] = {
> HV_PARTITION_PROPERTY_PROCESSOR_FEATURES0,
> @@ -181,6 +183,11 @@ static int create_partition(int mshv_fd, int *vm_fd)
> }
> args.pt_cpu_fbanks[1] = ~host_proc_features;
>
> + /* features we disable regardless of host support */
> + disabled_proc_features.la57_support = 1;
> + args.pt_cpu_fbanks[0] |= disabled_proc_features.as_uint64[0];
> + args.pt_cpu_fbanks[1] |= disabled_proc_features.as_uint64[1];
> +
> /* populate args structure */
> args.pt_flags = pt_flags;
> args.pt_isolation = MSHV_PT_ISOLATION_NONE;
> diff --git a/target/i386/mshv/mshv-cpu.c b/target/i386/mshv/mshv-cpu.c
> index 2c66a52709..31fb788657 100644
> --- a/target/i386/mshv/mshv-cpu.c
> +++ b/target/i386/mshv/mshv-cpu.c
> @@ -1677,6 +1677,12 @@ uint32_t mshv_get_supported_cpuid(uint32_t func,
> uint32_t idx, int reg)
> */
> if (func == 0x07 && idx == 0 && reg == R_ECX) {
> ret &= ~CPUID_7_0_ECX_CET_SHSTK;
> + /*
> + * LA57 (5-level paging) causes incorrect GVA=>GPA translations
> + * in the instruction decoder/emulator. Disable until page table
> + * walk in x86_mmu.c works w/ 5-level paging.
> + */
> + ret &= ~CPUID_7_0_ECX_LA57;
> }
> if (func == 0x07 && idx == 0 && reg == R_EDX) {
> ret &= ~CPUID_7_0_EDX_CET_IBT;
> --
> 2.34.1
>
>