summaryrefslogtreecommitdiff
path: root/src/arch/x86/insts/microop.hh
diff options
context:
space:
mode:
Diffstat (limited to 'src/arch/x86/insts/microop.hh')
-rw-r--r--src/arch/x86/insts/microop.hh10
1 files changed, 9 insertions, 1 deletions
diff --git a/src/arch/x86/insts/microop.hh b/src/arch/x86/insts/microop.hh
index 6fc215452..e5248c9ce 100644
--- a/src/arch/x86/insts/microop.hh
+++ b/src/arch/x86/insts/microop.hh
@@ -100,7 +100,15 @@ namespace X86ISA
X86ISA::X86StaticInst(mnem, _machInst, __opClass),
instMnem(_instMnem)
{
- flags |= setFlags;
+ const int ChunkSize = sizeof(unsigned long);
+ const int Chunks = sizeof(setFlags) / ChunkSize;
+
+ // Since the bitset constructor can only handle unsigned long
+ // sized chunks, feed it those one at a time while oring them in.
+ for (int i = 0; i < Chunks; i++) {
+ unsigned shift = i * ChunkSize * 8;
+ flags |= (std::bitset<NumFlags>(setFlags >> shift) << shift);
+ }
}
std::string generateDisassembly(Addr pc,