Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/lib/libnvmm Fix handling of SIB instructions. We were jumpin...
details: https://anonhg.NetBSD.org/src/rev/1d5d19255fa9
branches: trunk
changeset: 997007:1d5d19255fa9
user: maxv <maxv%NetBSD.org@localhost>
date: Sun Feb 17 20:25:46 2019 +0000
description:
Fix handling of SIB instructions. We were jumping to the SIB node _before_
fetching the displacement, so the node would always think there was no
displacement.
This didn't alter the final GPA we would be touching - because it is
fetched from the kernel directly and not from the computation -, but it
altered the instruction length, and on some guests (like Fedora 64bit),
the VCPU would resume execution at the wrong RIP and crash.
Now these guests work.
diffstat:
lib/libnvmm/libnvmm_x86.c | 8 ++++----
1 files changed, 4 insertions(+), 4 deletions(-)
diffs (28 lines):
diff -r ba8094df053c -r 1d5d19255fa9 lib/libnvmm/libnvmm_x86.c
--- a/lib/libnvmm/libnvmm_x86.c Sun Feb 17 14:04:31 2019 +0000
+++ b/lib/libnvmm/libnvmm_x86.c Sun Feb 17 20:25:46 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: libnvmm_x86.c,v 1.23 2019/02/15 16:42:27 maxv Exp $ */
+/* $NetBSD: libnvmm_x86.c,v 1.24 2019/02/17 20:25:46 maxv Exp $ */
/*
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -2233,15 +2233,15 @@
strg->u.reg = reg;
}
+ /* The displacement applies to RM. */
+ strm->disp.type = get_disp_type(instr);
+
if (has_sib(instr)) {
/* Overwrites RM */
fsm_advance(fsm, 1, node_sib);
return 0;
}
- /* The displacement applies to RM. */
- strm->disp.type = get_disp_type(instr);
-
if (is_rip_relative(fsm, instr)) {
/* Overwrites RM */
strm->type = STORE_REG;
Home |
Main Index |
Thread Index |
Old Index