diff options
author | Sean Christopherson <[email protected]> | 2020-12-17 16:31:37 -0800 |
---|---|---|
committer | Paolo Bonzini <[email protected]> | 2021-01-07 18:00:24 -0500 |
commit | 39b4d43e6003cee51cd119596d3c33d0449eb44c (patch) | |
tree | ddfaa6dcd1d932ddde050e1aff9a20d695bab5b0 /scripts/gdb/linux/timerlist.py | |
parent | 2aa078932ff6c66bf10cc5b3144440dbfa7d813d (diff) |
KVM: x86/mmu: Get root level from walkers when retrieving MMIO SPTE
Get the so called "root" level from the low level shadow page table
walkers instead of manually attempting to calculate it higher up the
stack, e.g. in get_mmio_spte(). When KVM is using PAE shadow paging,
the starting level of the walk, from the callers perspective, is not
the CR3 root but rather the PDPTR "root". Checking for reserved bits
from the CR3 root causes get_mmio_spte() to consume uninitialized stack
data due to indexing into sptes[] for a level that was not filled by
get_walk(). This can result in false positives and/or negatives
depending on what garbage happens to be on the stack.
Opportunistically nuke a few extra newlines.
Fixes: 95fb5b0258b7 ("kvm: x86/mmu: Support MMIO in the TDP MMU")
Reported-by: Richard Herbert <[email protected]>
Cc: Ben Gardon <[email protected]>
Cc: [email protected]
Signed-off-by: Sean Christopherson <[email protected]>
Message-Id: <[email protected]>
Signed-off-by: Paolo Bonzini <[email protected]>
Diffstat (limited to 'scripts/gdb/linux/timerlist.py')
0 files changed, 0 insertions, 0 deletions