summaryrefslogtreecommitdiff
path: root/tools/perf/scripts/python/export-to-sqlite.py
diff options
context:
space:
mode:
authorBen Gardon <bgardon@google.com>2021-02-02 21:57:19 +0300
committerPaolo Bonzini <pbonzini@redhat.com>2021-02-04 13:27:40 +0300
commited5e484b79e8a9b8be714bd85b6fc70bd6dc99a7 (patch)
tree7539c9764a9f789c9d02c337044cd988ec893206 /tools/perf/scripts/python/export-to-sqlite.py
parent74953d3530280dc53256054e1906f58d07bfba44 (diff)
downloadlinux-ed5e484b79e8a9b8be714bd85b6fc70bd6dc99a7.tar.xz
KVM: x86/mmu: Ensure forward progress when yielding in TDP MMU iter
In some functions the TDP iter risks not making forward progress if two threads livelock yielding to one another. This is possible if two threads are trying to execute wrprot_gfn_range. Each could write protect an entry and then yield. This would reset the tdp_iter's walk over the paging structure and the loop would end up repeating the same entry over and over, preventing either thread from making forward progress. Fix this issue by only yielding if the loop has made forward progress since the last yield. Fixes: a6a0b05da9f3 ("kvm: x86/mmu: Support dirty logging for the TDP MMU") Reviewed-by: Peter Feiner <pfeiner@google.com> Signed-off-by: Ben Gardon <bgardon@google.com> Message-Id: <20210202185734.1680553-14-bgardon@google.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'tools/perf/scripts/python/export-to-sqlite.py')
0 files changed, 0 insertions, 0 deletions