diff options
author | Tianyu Lan <[email protected]> | 2019-09-02 20:41:43 +0800 |
---|---|---|
committer | Ingo Molnar <[email protected]> | 2019-09-02 19:57:19 +0200 |
commit | 4030b4c585c41eeefec7bd20ce3d0e100a0f2e4d (patch) | |
tree | 7690ee68cc3ce82fba4c4410d601cf999b68cc72 /tools/perf/scripts/python/export-to-sqlite.py | |
parent | 9b8bd476e78e89c9ea26c3b435ad0201c3d7dbf5 (diff) |
x86/hyper-v: Fix overflow bug in fill_gva_list()
When the 'start' parameter is >= 0xFF000000 on 32-bit
systems, or >= 0xFFFFFFFF'FF000000 on 64-bit systems,
fill_gva_list() gets into an infinite loop.
With such inputs, 'cur' overflows after adding HV_TLB_FLUSH_UNIT
and always compares as less than end. Memory is filled with
guest virtual addresses until the system crashes.
Fix this by never incrementing 'cur' to be larger than 'end'.
Reported-by: Jong Hyun Park <[email protected]>
Signed-off-by: Tianyu Lan <[email protected]>
Reviewed-by: Michael Kelley <[email protected]>
Cc: Borislav Petkov <[email protected]>
Cc: Linus Torvalds <[email protected]>
Cc: Peter Zijlstra <[email protected]>
Cc: Thomas Gleixner <[email protected]>
Fixes: 2ffd9e33ce4a ("x86/hyper-v: Use hypercall for remote TLB flush")
Signed-off-by: Ingo Molnar <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/export-to-sqlite.py')
0 files changed, 0 insertions, 0 deletions