summaryrefslogtreecommitdiff
path: root/src/arch/x86/emulenv.cc
diff options
context:
space:
mode:
authorGabe Black <gblack@eecs.umich.edu>2009-02-27 09:23:58 -0800
committerGabe Black <gblack@eecs.umich.edu>2009-02-27 09:23:58 -0800
commit3dfa564e70e4804ef118ba94c81233fb85f56ba2 (patch)
tree0423a50010c4f19c3871c67eb72eb5c186d93e70 /src/arch/x86/emulenv.cc
parent9dfa3f7f735ead0ada9eb79227f217d0d76e0f49 (diff)
downloadgem5-3dfa564e70e4804ef118ba94c81233fb85f56ba2.tar.xz
X86: Respect segment override prefixes even when there's no ModRM byte.
Diffstat (limited to 'src/arch/x86/emulenv.cc')
-rw-r--r--src/arch/x86/emulenv.cc8
1 files changed, 8 insertions, 0 deletions
diff --git a/src/arch/x86/emulenv.cc b/src/arch/x86/emulenv.cc
index 30ed80942..0d7b32130 100644
--- a/src/arch/x86/emulenv.cc
+++ b/src/arch/x86/emulenv.cc
@@ -105,3 +105,11 @@ void EmulEnv::doModRM(const ExtMachInst & machInst)
}
}
+void EmulEnv::setSeg(const ExtMachInst & machInst)
+{
+ seg = SEGMENT_REG_DS;
+ //Handle any segment override that might have been in the instruction
+ int segFromInst = machInst.legacy.seg;
+ if (segFromInst)
+ seg = (SegmentRegIndex)(segFromInst - 1);
+}