diff options
author | Gabe Black <gblack@eecs.umich.edu> | 2009-02-27 09:23:58 -0800 |
---|---|---|
committer | Gabe Black <gblack@eecs.umich.edu> | 2009-02-27 09:23:58 -0800 |
commit | 3dfa564e70e4804ef118ba94c81233fb85f56ba2 (patch) | |
tree | 0423a50010c4f19c3871c67eb72eb5c186d93e70 /src/arch/x86/emulenv.cc | |
parent | 9dfa3f7f735ead0ada9eb79227f217d0d76e0f49 (diff) | |
download | gem5-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.cc | 8 |
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); +} |