29 #ifndef __ARCH_SPARC_INSTS_MICRO_HH__ 30 #define __ARCH_SPARC_INSTS_MICRO_HH__ 44 OpClass __opClass, uint32_t _numMicroops) :
46 numMicroops(_numMicroops)
50 flags[IsMacroop] =
true;
66 assert(upc < numMicroops);
73 panic(
"Tried to execute a macroop directly!\n");
79 panic(
"Tried to execute a macroop directly!\n");
85 panic(
"Tried to execute a macroop directly!\n");
97 flags[IsMicroop] =
true;
103 if (
flags[IsLastMicroop])
118 flags[IsDelayedCommit] =
true;
124 #endif // __ARCH_SPARC_INSTS_MICRO_HH__ #define panic(...)
This implements a cprintf based panic() function.
SparcMicroInst(const char *mnem, ExtMachInst _machInst, OpClass __opClass)
Fault completeAcc(PacketPtr, ExecContext *, Trace::InstRecord *) const override
SparcDelayedMicroInst(const char *mnem, ExtMachInst _machInst, OpClass __opClass)
void advancePC(SparcISA::PCState &pcState) const override
std::bitset< Num_Flags > flags
Flag values for this instruction.
Fault initiateAcc(ExecContext *, Trace::InstRecord *) const override
The ExecContext is an abstract base class the provides the interface used by the ISA to manipulate th...
SparcMacroInst(const char *mnem, ExtMachInst _machInst, OpClass __opClass, uint32_t _numMicroops)
Base class for all SPARC static instructions.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
StaticInstPtr fetchMicroop(MicroPC upc) const override
Return the microop that goes with a particular micropc.
TheISA::ExtMachInst ExtMachInst
Binary extended machine instruction type.
std::string generateDisassembly(Addr pc, const Loader::SymbolTable *symtab) const override
Internal function to generate disassembly string.
Fault execute(ExecContext *, Trace::InstRecord *) const override
std::shared_ptr< FaultBase > Fault
const uint32_t numMicroops