Go to the documentation of this file.
38 #ifndef __ARCH_X86_INSTS_MICROOP_HH__
39 #define __ARCH_X86_INSTS_MICROOP_HH__
51 namespace condition_tests
105 const char *mnem,
const char *_instMnem,
106 uint64_t setFlags, OpClass __opClass) :
110 const int ChunkSize =
sizeof(
unsigned long);
111 const int Chunks =
sizeof(setFlags) / ChunkSize;
115 for (
int i = 0;
i < Chunks;
i++) {
116 unsigned shift =
i * ChunkSize * 8;
125 std::stringstream
ss;
137 if (
flags[IsLastMicroop])
156 const char *inst_mnem, uint64_t set_flags, OpClass op_class,
166 #endif //__ARCH_X86_INSTS_MICROOP_HH__
PCState branchTarget(const PCState &branchPC) const override
GEM5_DEPRECATED_NAMESPACE(IntelMP, intelmp)
std::string generateDisassembly(Addr pc, const loader::SymbolTable *symtab) const override
Internal function to generate disassembly string.
void ccprintf(cp::Print &print)
bool checkCondition(uint64_t flags, int condition) const
virtual TheISA::PCState branchTarget(const TheISA::PCState &pc) const
Return the target address for a PC-relative branch.
std::bitset< Num_Flags > flags
Flag values for this instruction.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void advancePC(PCState &pcState) const override
Base class for all X86 static instructions.
MicroCondBase(ExtMachInst mach_inst, const char *mnem, const char *inst_mnem, uint64_t set_flags, OpClass op_class, uint8_t _cc)
X86MicroopBase(ExtMachInst _machInst, const char *mnem, const char *_instMnem, uint64_t setFlags, OpClass __opClass)
const char * mnemonic
Base mnemonic (e.g., "add").
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Generated on Tue Sep 7 2021 14:53:42 for gem5 by doxygen 1.8.17