• Xiao Guangrong's avatar
    KVM: MMU: don't write-protect if have new mapping to unsync page · e02aa901
    Xiao Guangrong authored
    Two cases maybe happen in kvm_mmu_get_page() function:
    
    - one case is, the goal sp is already in cache, if the sp is unsync,
      we only need update it to assure this mapping is valid, but not
      mark it sync and not write-protect sp->gfn since it not broke unsync
      rule(one shadow page for a gfn)
    
    - another case is, the goal sp not existed, we need create a new sp
      for gfn, i.e, gfn (may)has another shadow page, to keep unsync rule,
      we should sync(mark sync and write-protect) gfn's unsync shadow page.
      After enabling multiple unsync shadows, we sync those shadow pages
      only when the new sp not allow to become unsync(also for the unsyc
      rule, the new rule is: allow all pte page become unsync)
    Signed-off-by: default avatarXiao Guangrong <xiaoguangrong@cn.fujitsu.com>
    Signed-off-by: default avatarAvi Kivity <avi@redhat.com>
    e02aa901
mmu.c 81.9 KB