diff options
author | Nilay Vaish <nilay@cs.wisc.edu> | 2013-01-22 00:10:10 -0600 |
---|---|---|
committer | Nilay Vaish <nilay@cs.wisc.edu> | 2013-01-22 00:10:10 -0600 |
commit | fc57ae640130c2d7610f4ff20a3d8816b88042bf (patch) | |
tree | 80da33f0f19a5e21cfeed4e94d8ea45d6db27076 /src/arch/x86 | |
parent | 62544f938a8a7387bd22b397d36c637a2656f34a (diff) | |
download | gem5-fc57ae640130c2d7610f4ff20a3d8816b88042bf.tar.xz |
x86, cpu: corrects 270c9a75e91f, take over decoder on cpu switch
The changes made by the changeset 270c9a75e91f do not work well with switching
of cpus. The problem is that decoder for the old thread context holds state
that is not taken over by the new decoder.
This patch adds a takeOverFrom() function to Decoder class in each ISA. Except
for x86, functions in other ISAs are blank. For x86, the function copies state
from the old decoder to the new decoder.
Diffstat (limited to 'src/arch/x86')
-rw-r--r-- | src/arch/x86/decoder.hh | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/src/arch/x86/decoder.hh b/src/arch/x86/decoder.hh index 6f55ab26f..ca7ef96fe 100644 --- a/src/arch/x86/decoder.hh +++ b/src/arch/x86/decoder.hh @@ -250,6 +250,19 @@ class Decoder } } + void takeOverFrom(Decoder *old) + { + mode = old->mode; + submode = old->submode; + emi.mode.mode = mode; + emi.mode.submode = submode; + altOp = old->altOp; + defOp = old->defOp; + altAddr = old->altAddr; + defAddr = old->defAddr; + stack = old->stack; + } + void reset() { state = ResetState; |