target-i386: introduce support for 1 GB pages
Given the simplifications to the code in the previous patches, this is now very simple to do. Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
b052e4509b
commit
77549a7809
@ -569,9 +569,7 @@ struct X86CPUDefinition {
|
|||||||
CPUID_EXT_RDRAND */
|
CPUID_EXT_RDRAND */
|
||||||
#define TCG_EXT2_FEATURES ((TCG_FEATURES & CPUID_EXT2_AMD_ALIASES) | \
|
#define TCG_EXT2_FEATURES ((TCG_FEATURES & CPUID_EXT2_AMD_ALIASES) | \
|
||||||
CPUID_EXT2_NX | CPUID_EXT2_MMXEXT | CPUID_EXT2_RDTSCP | \
|
CPUID_EXT2_NX | CPUID_EXT2_MMXEXT | CPUID_EXT2_RDTSCP | \
|
||||||
CPUID_EXT2_3DNOW | CPUID_EXT2_3DNOWEXT)
|
CPUID_EXT2_3DNOW | CPUID_EXT2_3DNOWEXT | CPUID_EXT2_PDPE1GB)
|
||||||
/* missing:
|
|
||||||
CPUID_EXT2_PDPE1GB */
|
|
||||||
#define TCG_EXT3_FEATURES (CPUID_EXT3_LAHF_LM | CPUID_EXT3_SVM | \
|
#define TCG_EXT3_FEATURES (CPUID_EXT3_LAHF_LM | CPUID_EXT3_SVM | \
|
||||||
CPUID_EXT3_CR8LEG | CPUID_EXT3_ABM | CPUID_EXT3_SSE4A)
|
CPUID_EXT3_CR8LEG | CPUID_EXT3_ABM | CPUID_EXT3_SSE4A)
|
||||||
#define TCG_SVM_FEATURES 0
|
#define TCG_SVM_FEATURES 0
|
||||||
|
@ -605,6 +605,13 @@ int x86_cpu_handle_mmu_fault(CPUState *cs, vaddr addr,
|
|||||||
pdpe |= PG_ACCESSED_MASK;
|
pdpe |= PG_ACCESSED_MASK;
|
||||||
stl_phys_notdirty(cs->as, pdpe_addr, pdpe);
|
stl_phys_notdirty(cs->as, pdpe_addr, pdpe);
|
||||||
}
|
}
|
||||||
|
if (pdpe & PG_PSE_MASK) {
|
||||||
|
/* 1 GB page */
|
||||||
|
page_size = 1024 * 1024 * 1024;
|
||||||
|
pte_addr = pdpe_addr;
|
||||||
|
pte = pdpe;
|
||||||
|
goto do_check_protect;
|
||||||
|
}
|
||||||
} else
|
} else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user