• P
    KVM: x86/mmu: remove redundant bits from extended role · faf72962
    Paolo Bonzini 提交于
    Before the separation of the CPU and the MMU role, CR0.PG was not
    available in the base MMU role, because two-dimensional paging always
    used direct=1 in the MMU role.  However, now that the raw role is
    snapshotted in mmu->cpu_role, the value of CR0.PG always matches both
    !cpu_role.base.direct and cpu_role.base.level > 0.  There is no need to
    store it again in union kvm_mmu_extended_role; instead, write an is_cr0_pg
    accessor by hand that takes care of the conversion.  Use cpu_role.base.level
    since the future of the direct field is unclear.
    
    Likewise, CR4.PAE is now always present in the CPU role as
    !cpu_role.base.has_4_byte_gpte.  The inversion makes certain tests on
    the MMU role easier, and is easily hidden by the is_cr4_pae accessor
    when operating on the CPU role.
    Signed-off-by: NPaolo Bonzini <pbonzini@redhat.com>
    faf72962
kvm_host.h 60.1 KB